home *** CD-ROM | disk | FTP | other *** search
/ BBS in a Box 10 / BBS In A Box Volume X (AMUG) (January 1994).bin / Files / Prog / U-Z / VideoToolBox.cpt / Utilities / CalibrateLuminance / CalibrateLuminance.c next >
MacBinary  |  1993-03-04  |  38.0 KB  |  [TEXT/KAHL]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Thu Mar 4 02:19:43 1993, modified Thu Mar 4 02:19:43 1993, creator Think C, type ASCII, 38205 bytes "CalibrateLuminance.c" , at 0x95bd 454 bytes resource default (weak)
99% file data default
49% TrID Macintosh plain text (MacBinary) default
33% TrID raw Group 3 FAX bitmap default (weak)
16% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[KAHL]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 14 43 61 6c 69 62 72 | 61 74 65 4c 75 6d 69 6e |..Calibr|ateLumin|
|00000010| 61 6e 63 65 2e 63 00 00 | 00 00 00 00 00 00 00 00 |ance.c..|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4b 41 48 | 4c 01 00 00 00 00 00 00 |.TEXTKAH|L.......|
|00000050| 00 00 00 00 00 95 3d 00 | 00 01 c6 a7 bb 5e 0f a7 |......=.|.....^..|
|00000060| bb 5e 0f 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |.^......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 48 44 00 00 |........|....HD..|
|00000080| 2f 2a 0d 43 61 6c 69 62 | 72 61 74 65 4c 75 6d 69 |/*.Calib|rateLumi|
|00000090| 6e 61 6e 63 65 2e 63 0d | 62 79 20 44 65 6e 69 73 |nance.c.|by Denis|
|000000a0| 20 50 65 6c 6c 69 2c 20 | 4c 61 6e 20 5a 68 61 6e | Pelli, |Lan Zhan|
|000000b0| 67 2c 20 61 6e 64 20 50 | 72 65 65 74 69 20 56 65 |g, and P|reeti Ve|
|000000c0| 72 67 68 65 73 65 0d 59 | 6f 75 20 77 69 6c 6c 20 |rghese.Y|ou will |
|000000d0| 6e 65 65 64 20 22 4e 75 | 6d 65 72 69 63 61 6c 20 |need "Nu|merical |
|000000e0| 52 65 63 69 70 65 73 20 | 69 6e 20 43 22 20 69 6e |Recipes |in C" in|
|000000f0| 20 6f 72 64 65 72 20 74 | 6f 20 63 6f 6d 70 69 6c | order t|o compil|
|00000100| 65 20 74 68 69 73 20 66 | 69 6c 65 3b 20 73 65 65 |e this f|ile; see|
|00000110| 0d 6c 69 6d 69 74 61 74 | 69 6f 6e 73 20 62 65 6c |.limitat|ions bel|
|00000120| 6f 77 2e 0d 0d 55 53 45 | 0d 0d 59 6f 75 20 6d 75 |ow...USE|..You mu|
|00000130| 73 74 20 72 75 6e 20 74 | 68 69 73 20 70 72 6f 67 |st run t|his prog|
|00000140| 72 61 6d 20 28 6f 72 20 | 79 6f 75 72 20 6f 77 6e |ram (or |your own|
|00000150| 20 65 71 75 69 76 61 6c | 65 6e 74 29 20 74 6f 20 | equival|ent) to |
|00000160| 63 61 6c 69 62 72 61 74 | 65 20 79 6f 75 72 20 76 |calibrat|e your v|
|00000170| 69 64 65 6f 20 63 61 72 | 64 2c 0d 49 53 52 20 56 |ideo car|d,.ISR V|
|00000180| 69 64 65 6f 20 41 74 74 | 65 6e 75 61 74 6f 72 2c |ideo Att|enuator,|
|00000190| 20 61 6e 64 20 6d 6f 6e | 6f 63 68 72 6f 6d 65 20 | and mon|ochrome |
|000001a0| 6d 6f 6e 69 74 6f 72 2c | 20 61 73 20 64 65 73 63 |monitor,| as desc|
|000001b0| 72 69 62 65 64 20 62 79 | 20 50 65 6c 6c 69 20 26 |ribed by| Pelli &|
|000001c0| 20 5a 68 61 6e 67 0d 28 | 31 39 39 31 29 2e 0d 0d | Zhang.(|1991)...|
|000001d0| 44 2e 47 2e 20 50 65 6c | 6c 69 20 61 6e 64 20 4c |D.G. Pel|li and L|
|000001e0| 2e 20 5a 68 61 6e 67 20 | 28 31 39 39 31 29 20 41 |. Zhang |(1991) A|
|000001f0| 63 63 75 72 61 74 65 20 | 63 6f 6e 74 72 6f 6c 20 |ccurate |control |
|00000200| 6f 66 20 63 6f 6e 74 72 | 61 73 74 20 6f 6e 20 6d |of contr|ast on m|
|00000210| 69 63 72 6f 63 6f 6d 70 | 75 74 65 72 0d 64 69 73 |icrocomp|uter.dis|
|00000220| 70 6c 61 79 73 2e 20 56 | 69 73 69 6f 6e 20 52 65 |plays. V|ision Re|
|00000230| 73 65 61 72 63 68 2c 20 | 33 31 3a 31 33 33 37 2d |search, |31:1337-|
|00000240| 31 33 36 30 2e 0d 0d 54 | 68 65 20 70 72 6f 67 72 |1360...T|he progr|
|00000250| 61 6d 27 73 20 72 65 73 | 75 6c 74 73 20 61 72 65 |am's res|ults are|
|00000260| 20 73 74 6f 72 65 64 20 | 69 6e 20 61 20 66 69 6c | stored |in a fil|
|00000270| 65 20 63 61 6c 6c 65 64 | 20 4c 75 6d 69 6e 61 6e |e called| Luminan|
|00000280| 63 65 52 65 63 6f 72 64 | 3f 2e 68 20 74 68 61 74 |ceRecord|?.h that|
|00000290| 20 79 6f 75 0d 63 61 6e | 20 74 68 65 6e 20 75 73 | you.can| then us|
|000002a0| 65 20 69 6e 20 74 68 65 | 20 72 65 73 74 20 6f 66 |e in the| rest of|
|000002b0| 20 79 6f 75 72 20 43 20 | 70 72 6f 67 72 61 6d 73 | your C |programs|
|000002c0| 2e 20 22 3f 22 20 77 69 | 6c 6c 20 62 65 20 61 20 |. "?" wi|ll be a |
|000002d0| 64 69 67 69 74 20 69 6e | 64 69 63 61 74 69 6e 67 |digit in|dicating|
|000002e0| 0d 77 68 69 63 68 20 6d | 6f 6e 69 74 6f 72 2e 20 |.which m|onitor. |
|000002f0| 4c 75 6d 69 6e 61 6e 63 | 65 52 65 63 6f 72 64 3f |Luminanc|eRecord?|
|00000300| 2e 68 20 64 65 73 63 72 | 69 62 65 73 20 74 68 65 |.h descr|ibes the|
|00000310| 20 67 61 69 6e 73 20 6f | 66 20 74 68 65 20 74 68 | gains o|f the th|
|00000320| 72 65 65 20 76 69 64 65 | 6f 0d 70 61 74 68 77 61 |ree vide|o.pathwa|
|00000330| 79 73 20 6f 66 20 79 6f | 75 72 20 76 69 64 65 6f |ys of yo|ur video|
|00000340| 20 63 61 72 64 20 61 6e | 64 20 49 53 52 20 56 69 | card an|d ISR Vi|
|00000350| 64 65 6f 20 41 74 74 65 | 6e 75 61 74 6f 72 2c 20 |deo Atte|nuator, |
|00000360| 61 6e 64 20 64 65 73 63 | 72 69 62 65 73 20 74 68 |and desc|ribes th|
|00000370| 65 20 67 61 6d 6d 61 0d | 66 75 6e 63 74 69 6f 6e |e gamma.|function|
|00000380| 20 6f 66 20 79 6f 75 72 | 20 6d 6f 6e 69 74 6f 72 | of your| monitor|
|00000390| 2c 20 74 6f 20 61 6c 6c | 6f 77 20 61 75 74 6f 6d |, to all|ow autom|
|000003a0| 61 74 69 63 20 67 61 6d | 6d 61 20 63 6f 72 72 65 |atic gam|ma corre|
|000003b0| 63 74 69 6f 6e 20 6c 61 | 74 65 72 2c 20 75 73 69 |ction la|ter, usi|
|000003c0| 6e 67 0d 53 65 74 4c 75 | 6d 69 6e 61 6e 63 65 28 |ng.SetLu|minance(|
|000003d0| 29 2c 20 65 74 63 2e 0d | 0d 54 68 65 72 65 20 61 |), etc..|.There a|
|000003e0| 72 65 20 74 77 6f 20 77 | 61 79 73 20 6f 66 20 75 |re two w|ays of u|
|000003f0| 73 69 6e 67 20 74 68 65 | 20 4c 75 6d 69 6e 61 6e |sing the| Luminan|
|00000400| 63 65 52 65 63 6f 72 64 | 20 66 69 6c 65 2e 20 59 |ceRecord| file. Y|
|00000410| 6f 75 20 63 61 6e 20 75 | 73 65 20 74 68 65 0d 70 |ou can u|se the.p|
|00000420| 72 65 70 72 6f 63 65 73 | 73 6f 72 20 23 69 6e 63 |reproces|sor #inc|
|00000430| 6c 75 64 65 20 73 74 61 | 74 65 6d 65 6e 74 2c 20 |lude sta|tement, |
|00000440| 69 6e 20 74 68 65 20 6d | 69 64 73 74 20 6f 66 20 |in the m|idst of |
|00000450| 79 6f 75 72 20 43 20 63 | 6f 64 65 2c 20 70 72 6f |your C c|ode, pro|
|00000460| 76 69 64 65 64 20 79 6f | 75 27 76 65 0d 67 6f 74 |vided yo|u've.got|
|00000470| 20 61 20 4c 75 6d 69 6e | 61 6e 63 65 52 65 63 6f | a Lumin|anceReco|
|00000480| 72 64 20 73 74 72 75 63 | 74 75 72 65 20 63 61 6c |rd struc|ture cal|
|00000490| 6c 65 64 20 4c 52 2e 20 | 4f 72 20 79 6f 75 20 63 |led LR. |Or you c|
|000004a0| 61 6e 20 75 73 65 20 74 | 68 65 20 56 69 64 65 6f |an use t|he Video|
|000004b0| 54 6f 6f 6c 62 6f 78 0d | 72 6f 75 74 69 6e 65 20 |Toolbox.|routine |
|000004c0| 63 61 6c 6c 65 64 20 52 | 65 61 64 4c 75 6d 69 6e |called R|eadLumin|
|000004d0| 61 6e 63 65 52 65 63 6f | 72 64 28 29 20 74 6f 20 |anceReco|rd() to |
|000004e0| 72 65 61 64 20 74 68 65 | 20 64 61 74 61 20 28 61 |read the| data (a|
|000004f0| 74 20 72 75 6e 74 69 6d | 65 29 20 69 6e 74 6f 20 |t runtim|e) into |
|00000500| 61 0d 4c 75 6d 69 6e 61 | 6e 63 65 52 65 63 6f 72 |a.Lumina|nceRecor|
|00000510| 64 20 6f 66 20 61 6e 79 | 20 6e 61 6d 65 2e 0d 0d |d of any| name...|
|00000520| 46 6f 72 20 68 69 73 74 | 6f 72 69 63 61 6c 20 72 |For hist|orical r|
|00000530| 65 61 73 6f 6e 73 20 74 | 68 69 73 20 70 72 6f 67 |easons t|his prog|
|00000540| 72 61 6d 20 6e 6f 74 20 | 6f 6e 6c 79 20 6d 65 61 |ram not |only mea|
|00000550| 73 75 72 65 73 20 74 68 | 65 20 67 61 6d 6d 61 20 |sures th|e gamma |
|00000560| 66 75 6e 63 74 69 6f 6e | 2c 20 62 75 74 0d 61 6c |function|, but.al|
|00000570| 73 6f 20 66 69 74 73 20 | 61 20 76 61 72 69 65 74 |so fits |a variet|
|00000580| 79 20 6f 66 20 66 75 6e | 63 74 69 6f 6e 73 20 74 |y of fun|ctions t|
|00000590| 6f 20 69 74 2e 20 49 6e | 20 66 61 63 74 20 74 68 |o it. In| fact th|
|000005a0| 65 20 6c 61 74 65 73 74 | 20 69 6d 70 6c 65 6d 65 |e latest| impleme|
|000005b0| 6e 74 61 74 69 6f 6e 20 | 6f 66 0d 4c 75 6d 69 6e |ntation |of.Lumin|
|000005c0| 61 6e 63 65 2e 63 2c 20 | 77 68 69 63 68 20 69 73 |ance.c, |which is|
|000005d0| 20 74 68 65 20 6f 6e 6c | 79 20 72 6f 75 74 69 6e | the onl|y routin|
|000005e0| 65 20 74 68 61 74 20 6d | 61 6b 65 73 20 64 69 72 |e that m|akes dir|
|000005f0| 65 63 74 20 75 73 65 20 | 6f 66 20 74 68 65 20 67 |ect use |of the g|
|00000600| 61 6d 6d 61 0d 64 65 73 | 63 72 69 70 74 69 6f 6e |amma.des|cription|
|00000610| 2c 20 77 6f 75 6c 64 20 | 62 65 20 71 75 69 74 65 |, would |be quite|
|00000620| 20 63 6f 6e 74 65 6e 74 | 20 77 69 74 68 20 6a 75 | content| with ju|
|00000630| 73 74 20 74 68 65 20 74 | 61 62 75 6c 61 74 65 64 |st the t|abulated|
|00000640| 20 67 61 6d 6d 61 20 66 | 75 6e 63 74 69 6f 6e 2e | gamma f|unction.|
|00000650| 20 41 74 0d 70 72 65 73 | 65 6e 74 20 74 68 65 20 | At.pres|ent the |
|00000660| 67 61 6d 6d 61 20 66 75 | 6e 63 74 69 6f 6e 20 69 |gamma fu|nction i|
|00000670| 73 20 74 61 62 75 6c 61 | 74 65 64 20 76 65 72 79 |s tabula|ted very|
|00000680| 20 63 6f 61 72 73 65 6c | 79 20 62 79 20 43 61 6c | coarsel|y by Cal|
|00000690| 69 62 72 61 74 65 4c 75 | 6d 69 6e 61 6e 63 65 2c |ibrateLu|minance,|
|000006a0| 20 73 6f 0d 69 74 20 64 | 6f 65 73 6e 27 74 20 62 | so.it d|oesn't b|
|000006b0| 6f 74 68 65 72 20 74 6f | 20 70 75 74 20 74 68 69 |other to| put thi|
|000006c0| 73 20 74 61 62 6c 65 20 | 69 6e 74 6f 20 74 68 65 |s table |into the|
|000006d0| 20 69 6e 63 6c 75 64 65 | 20 66 69 6c 65 20 4c 75 | include| file Lu|
|000006e0| 6d 69 6e 61 6e 63 65 52 | 65 63 6f 72 64 2e 68 2e |minanceR|ecord.h.|
|000006f0| 0d 48 6f 77 65 76 65 72 | 2c 20 69 66 20 79 6f 75 |.However|, if you|
|00000700| 27 64 20 72 61 74 68 65 | 72 20 77 72 69 74 65 20 |'d rathe|r write |
|00000710| 79 6f 75 72 20 6f 77 6e | 20 73 75 62 73 74 69 74 |your own| substit|
|00000720| 75 74 65 20 66 6f 72 20 | 74 68 69 73 20 70 72 6f |ute for |this pro|
|00000730| 67 72 61 6d 2c 20 74 68 | 65 6e 20 49 0d 77 6f 75 |gram, th|en I.wou|
|00000740| 6c 64 20 73 75 67 67 65 | 73 74 20 6a 75 73 74 20 |ld sugge|st just |
|00000750| 6d 65 61 73 75 72 69 6e | 67 20 74 68 65 20 6c 75 |measurin|g the lu|
|00000760| 6d 69 6e 61 6e 63 65 20 | 61 74 20 32 35 36 20 64 |minance |at 256 d|
|00000770| 69 66 66 65 72 65 6e 74 | 20 6c 65 76 65 6c 73 20 |ifferent| levels |
|00000780| 28 66 72 6f 6d 20 30 20 | 74 6f 0d 56 4d 61 78 29 |(from 0 |to.VMax)|
|00000790| 20 61 6e 64 20 73 61 76 | 69 6e 67 20 74 68 65 20 | and sav|ing the |
|000007a0| 74 61 62 6c 65 20 69 6e | 20 74 68 65 20 69 6e 63 |table in| the inc|
|000007b0| 6c 75 64 65 20 66 69 6c | 65 2e 20 59 6f 75 20 77 |lude fil|e. You w|
|000007c0| 69 6c 6c 20 61 6c 73 6f | 20 6e 65 65 64 20 74 6f |ill also| need to|
|000007d0| 20 6d 65 61 73 75 72 65 | 0d 74 68 65 20 52 47 42 | measure|.the RGB|
|000007e0| 20 67 61 69 6e 73 2c 20 | 62 75 74 20 74 68 61 74 | gains, |but that|
|000007f0| 20 63 61 6e 20 65 61 73 | 69 6c 79 20 62 65 20 64 | can eas|ily be d|
|00000800| 6f 6e 65 20 64 69 72 65 | 63 74 6c 79 2c 20 75 73 |one dire|ctly, us|
|00000810| 69 6e 67 20 61 6e 20 6f | 73 63 69 6c 6c 6f 73 63 |ing an o|scillosc|
|00000820| 6f 70 65 2c 0d 72 61 74 | 68 65 72 20 74 68 61 6e |ope,.rat|her than|
|00000830| 20 74 72 79 69 6e 67 20 | 74 6f 20 62 65 20 63 6c | trying |to be cl|
|00000840| 65 76 65 72 2c 20 61 73 | 20 69 6e 20 68 65 72 65 |ever, as| in here|
|00000850| 2c 20 77 68 65 72 65 20 | 77 65 20 69 6e 76 65 72 |, where |we inver|
|00000860| 74 20 74 68 65 20 6e 6f | 6e 6c 69 6e 65 61 72 69 |t the no|nlineari|
|00000870| 74 79 20 74 6f 0d 69 6e | 66 65 72 20 76 6f 6c 74 |ty to.in|fer volt|
|00000880| 61 67 65 73 20 66 72 6f | 6d 20 74 68 65 20 6e 6f |ages fro|m the no|
|00000890| 6e 6c 69 6e 65 61 72 20 | 6c 75 6d 69 6e 61 6e 63 |nlinear |luminanc|
|000008a0| 65 73 20 74 68 61 74 20 | 77 65 20 6d 65 61 73 75 |es that |we measu|
|000008b0| 72 65 2e 0d 0d 43 61 6c | 69 62 72 61 74 65 4c 75 |re...Cal|ibrateLu|
|000008c0| 6d 69 6e 61 6e 63 65 20 | 61 6c 73 6f 20 70 72 6f |minance |also pro|
|000008d0| 64 75 63 65 73 20 61 20 | 43 72 69 63 6b 65 74 47 |duces a |CricketG|
|000008e0| 72 61 70 68 20 66 69 6c | 65 2c 20 43 61 6c 69 62 |raph fil|e, Calib|
|000008f0| 72 61 74 65 4c 75 6d 69 | 6e 61 6e 63 65 25 64 2e |rateLumi|nance%d.|
|00000900| 64 61 74 61 0d 28 77 68 | 65 72 65 20 25 64 20 69 |data.(wh|ere %d i|
|00000910| 73 20 72 65 70 6c 61 63 | 65 64 20 62 79 20 74 68 |s replac|ed by th|
|00000920| 65 20 6d 6f 6e 69 74 6f | 72 20 6e 75 6d 62 65 72 |e monito|r number|
|00000930| 29 2c 20 77 68 69 63 68 | 20 69 73 20 73 75 69 74 |), which| is suit|
|00000940| 61 62 6c 65 20 66 6f 72 | 20 67 72 61 70 68 69 6e |able for| graphin|
|00000950| 67 20 74 68 65 0d 6d 6f | 6e 69 74 6f 72 27 73 20 |g the.mo|nitor's |
|00000960| 67 61 6d 6d 61 20 66 75 | 6e 63 74 69 6f 6e 2e 20 |gamma fu|nction. |
|00000970| 55 73 65 20 74 68 65 20 | 43 72 69 63 6b 65 74 47 |Use the |CricketG|
|00000980| 72 61 70 68 20 66 6f 72 | 6d 61 74 20 66 69 6c 65 |raph for|mat file|
|00000990| 0d 43 61 6c 69 62 72 61 | 74 65 4c 75 6d 69 6e 61 |.Calibra|teLumina|
|000009a0| 6e 63 65 2e 66 6f 72 6d | 61 74 2e 0d 0d 54 68 69 |nce.form|at...Thi|
|000009b0| 73 20 70 72 6f 67 72 61 | 6d 20 6d 65 61 73 75 72 |s progra|m measur|
|000009c0| 65 73 20 74 68 65 20 6c | 75 6d 69 6e 61 6e 63 65 |es the l|uminance|
|000009d0| 20 6f 66 20 61 20 70 61 | 74 63 68 20 6f 6e 20 74 | of a pa|tch on t|
|000009e0| 68 65 20 73 63 72 65 65 | 6e 2c 20 75 73 69 6e 67 |he scree|n, using|
|000009f0| 20 61 20 70 68 6f 74 6f | 6d 65 74 65 72 0d 61 6e | a photo|meter.an|
|00000a00| 64 2c 20 6f 70 74 69 6f | 6e 61 6c 6c 79 2c 20 61 |d, optio|nally, a|
|00000a10| 20 31 32 2d 62 69 74 20 | 41 6e 61 6c 6f 67 20 74 | 12-bit |Analog t|
|00000a20| 6f 20 44 69 67 69 74 61 | 6c 20 43 6f 6e 76 65 72 |o Digita|l Conver|
|00000a30| 74 65 72 20 28 41 44 43 | 29 2e 20 49 66 20 79 6f |ter (ADC|). If yo|
|00000a40| 75 20 68 61 76 65 20 61 | 20 44 61 74 61 0d 54 72 |u have a| Data.Tr|
|00000a50| 61 6e 73 6c 61 74 69 6f | 6e 20 46 6f 72 65 72 75 |anslatio|n Foreru|
|00000a60| 6e 6e 65 72 20 41 6e 61 | 6c 6f 67 2d 74 6f 2d 44 |nner Ana|log-to-D|
|00000a70| 69 67 69 74 61 6c 20 63 | 61 72 64 2c 20 74 68 65 |igital c|ard, the|
|00000a80| 6e 20 47 65 74 56 6f 6c | 74 61 67 65 2e 63 20 77 |n GetVol|tage.c w|
|00000a90| 69 6c 6c 0d 61 75 74 6f | 6d 61 74 69 63 61 6c 6c |ill.auto|maticall|
|00000aa0| 79 20 66 69 6e 64 20 61 | 6e 64 20 75 73 65 20 69 |y find a|nd use i|
|00000ab0| 74 2e 20 59 6f 75 20 63 | 61 6e 20 73 65 74 20 74 |t. You c|an set t|
|00000ac0| 68 65 20 4d 41 4e 55 41 | 4c 20 66 6c 61 67 20 74 |he MANUA|L flag t|
|00000ad0| 6f 20 66 6f 72 63 65 20 | 6d 61 6e 75 61 6c 0d 6f |o force |manual.o|
|00000ae0| 70 65 72 61 74 69 6f 6e | 2e 20 49 66 20 79 6f 75 |peration|. If you|
|00000af0| 72 20 70 68 6f 74 6f 6d | 65 74 65 72 20 68 61 73 |r photom|eter has|
|00000b00| 20 61 6e 20 61 6e 61 6c | 6f 67 20 6f 75 74 70 75 | an anal|og outpu|
|00000b10| 74 2c 20 69 74 27 73 20 | 63 6f 6e 76 65 6e 69 65 |t, it's |convenie|
|00000b20| 6e 74 20 61 6e 64 20 6d | 6f 72 65 0d 61 63 63 75 |nt and m|ore.accu|
|00000b30| 72 61 74 65 20 74 6f 20 | 68 61 76 65 20 61 6c 6c |rate to |have all|
|00000b40| 20 74 68 65 20 76 6f 6c | 74 61 67 65 73 20 72 65 | the vol|tages re|
|00000b50| 61 64 20 69 6e 20 61 75 | 74 6f 6d 61 74 69 63 61 |ad in au|tomatica|
|00000b60| 6c 6c 79 20 76 69 61 20 | 61 6e 20 41 44 43 2c 20 |lly via |an ADC, |
|00000b70| 62 75 74 20 79 6f 75 0d | 77 6f 6e 27 74 20 6e 65 |but you.|won't ne|
|00000b80| 65 64 20 74 6f 20 72 75 | 6e 20 43 61 6c 69 62 72 |ed to ru|n Calibr|
|00000b90| 61 74 65 4c 75 6d 69 6e | 61 6e 63 65 20 76 65 72 |ateLumin|ance ver|
|00000ba0| 79 20 6f 66 74 65 6e 2c | 20 61 6e 64 20 79 6f 75 |y often,| and you|
|00000bb0| 20 63 61 6e 20 67 65 74 | 20 62 79 20 77 69 74 68 | can get| by with|
|00000bc0| 20 6d 61 6e 75 61 6c 0d | 63 61 6c 69 62 72 61 74 | manual.|calibrat|
|00000bd0| 69 6f 6e 2e 0d 0d 59 6f | 75 20 73 68 6f 75 6c 64 |ion...Yo|u should|
|00000be0| 20 73 65 74 20 74 68 65 | 20 62 61 63 6b 67 72 6f | set the| backgro|
|00000bf0| 75 6e 64 20 6c 75 6d 69 | 6e 61 6e 63 65 20 74 6f |und lumi|nance to|
|00000c00| 20 61 70 70 72 6f 78 69 | 6d 61 74 65 6c 79 20 74 | approxi|mately t|
|00000c10| 68 65 20 73 61 6d 65 20 | 76 61 6c 75 65 20 61 73 |he same |value as|
|00000c20| 20 79 6f 75 0d 77 69 6c | 6c 20 75 73 65 20 69 6e | you.wil|l use in|
|00000c30| 20 79 6f 75 72 20 65 78 | 70 65 72 69 6d 65 6e 74 | your ex|periment|
|00000c40| 2e 20 4e 6f 74 65 20 74 | 68 61 74 20 74 68 65 20 |. Note t|hat the |
|00000c50| 63 68 61 6e 6e 65 6c 73 | 20 67 61 69 6e 73 20 64 |channels| gains d|
|00000c60| 65 70 65 6e 64 20 6f 6e | 20 74 68 65 20 44 41 43 |epend on| the DAC|
|00000c70| 73 20 61 73 0d 77 65 6c | 6c 20 61 73 20 74 68 65 |s as.wel|l as the|
|00000c80| 20 49 53 52 20 56 69 64 | 65 6f 20 41 74 74 65 6e | ISR Vid|eo Atten|
|00000c90| 75 61 74 6f 72 2c 20 61 | 6e 64 20 77 69 6c 6c 20 |uator, a|nd will |
|00000ca0| 76 61 72 79 20 66 72 6f | 6d 20 44 41 43 20 74 6f |vary fro|m DAC to|
|00000cb0| 20 44 41 43 20 62 79 20 | b1 35 25 2e 20 54 68 61 | DAC by |.5%. Tha|
|00000cc0| 74 27 73 0d 77 68 79 20 | 79 6f 75 20 6d 75 73 74 |t's.why |you must|
|00000cd0| 20 64 6f 20 74 68 69 73 | 20 63 61 6c 69 62 72 61 | do this| calibra|
|00000ce0| 74 69 6f 6e 20 79 6f 75 | 72 73 65 6c 66 20 75 73 |tion you|rself us|
|00000cf0| 69 6e 67 20 79 6f 75 72 | 20 6f 77 6e 20 76 69 64 |ing your| own vid|
|00000d00| 65 6f 20 63 61 72 64 20 | 61 6e 64 20 6d 6f 6e 69 |eo card |and moni|
|00000d10| 74 6f 72 2e 0d 0d 54 68 | 69 73 20 70 72 6f 67 72 |tor...Th|is progr|
|00000d20| 61 6d 20 63 61 6e 20 63 | 61 6c 69 62 72 61 74 65 |am can c|alibrate|
|00000d30| 20 61 6e 79 20 6f 66 20 | 79 6f 75 72 20 73 63 72 | any of |your scr|
|00000d40| 65 65 6e 73 2c 20 69 6e | 63 6c 75 64 69 6e 67 20 |eens, in|cluding |
|00000d50| 74 68 65 20 6d 61 69 6e | 20 73 63 72 65 65 6e 2e |the main| screen.|
|00000d60| 20 49 74 0d 6e 6f 77 20 | 77 6f 72 6b 73 20 66 69 | It.now |works fi|
|00000d70| 6e 65 20 77 69 74 68 20 | 61 20 73 69 6e 67 6c 65 |ne with |a single|
|00000d80| 20 73 63 72 65 65 6e 2c | 20 61 6c 74 65 72 6e 61 | screen,| alterna|
|00000d90| 74 69 6e 67 20 74 68 65 | 20 75 73 65 72 20 64 69 |ting the| user di|
|00000da0| 61 6c 6f 67 20 77 69 74 | 68 20 74 68 65 0d 6d 65 |alog wit|h the.me|
|00000db0| 61 73 75 72 65 6d 65 6e | 74 73 2e 0d 0d 4c 49 4d |asuremen|ts...LIM|
|00000dc0| 49 54 41 54 49 4f 4e 53 | 0d 0d 43 61 6c 69 62 72 |ITATIONS|..Calibr|
|00000dd0| 61 74 65 4c 75 6d 69 6e | 61 6e 63 65 20 75 73 65 |ateLumin|ance use|
|00000de0| 73 20 72 6f 75 74 69 6e | 65 73 20 66 72 6f 6d 20 |s routin|es from |
|00000df0| 4e 75 6d 65 72 69 63 61 | 6c 20 52 65 63 69 70 65 |Numerica|l Recipe|
|00000e00| 73 20 69 6e 20 43 20 74 | 6f 20 64 6f 20 74 68 65 |s in C t|o do the|
|00000e10| 0d 70 6f 6c 79 6e 6f 6d | 69 61 6c 20 61 6e 64 20 |.polynom|ial and |
|00000e20| 70 6f 77 65 72 20 6c 61 | 77 20 66 69 74 73 20 74 |power la|w fits t|
|00000e30| 6f 20 74 68 65 20 67 61 | 6d 6d 61 20 66 75 6e 63 |o the ga|mma func|
|00000e40| 74 69 6f 6e 2e 20 54 68 | 65 79 27 72 65 20 63 6f |tion. Th|ey're co|
|00000e50| 70 79 72 69 67 68 74 65 | 64 2c 20 73 6f 20 49 0d |pyrighte|d, so I.|
|00000e60| 63 61 6e 27 74 20 64 69 | 73 74 72 69 62 75 74 65 |can't di|stribute|
|00000e70| 20 74 68 65 6d 2e 20 4e | 6f 74 65 3a 20 49 20 48 | them. N|ote: I H|
|00000e80| 41 56 45 20 69 6e 63 6c | 75 64 65 64 20 61 20 63 |AVE incl|uded a c|
|00000e90| 6f 6d 70 69 6c 65 64 20 | 61 70 70 6c 69 63 61 74 |ompiled |applicat|
|00000ea0| 69 6f 6e 0d 43 61 6c 69 | 62 72 61 74 65 4c 75 6d |ion.Cali|brateLum|
|00000eb0| 69 6e 61 6e 63 65 20 74 | 68 61 74 20 79 6f 75 20 |inance t|hat you |
|00000ec0| 63 61 6e 20 75 73 65 20 | 4e 4f 57 2e 20 59 6f 75 |can use |NOW. You|
|00000ed0| 20 6f 6e 6c 79 20 6e 65 | 65 64 20 74 6f 20 62 75 | only ne|ed to bu|
|00000ee0| 79 20 74 68 65 20 4e 75 | 6d 65 72 69 63 61 6c 0d |y the Nu|merical.|
|00000ef0| 52 65 63 69 70 65 73 20 | 69 66 20 79 6f 75 20 77 |Recipes |if you w|
|00000f00| 61 6e 74 20 74 6f 20 4d | 4f 44 49 46 59 20 43 61 |ant to M|ODIFY Ca|
|00000f10| 6c 69 62 72 61 74 65 4c | 75 6d 69 6e 61 6e 63 65 |librateL|uminance|
|00000f20| 2e 63 2e 20 53 65 65 20 | 22 49 6d 70 72 6f 76 65 |.c. See |"Improve|
|00000f30| 20 4e 75 6d 65 72 69 63 | 61 6c 20 52 65 63 69 70 | Numeric|al Recip|
|00000f40| 65 73 22 20 0d 69 6e 20 | 74 68 65 20 6e 6f 74 65 |es" .in |the note|
|00000f50| 73 20 66 6f 6c 64 65 72 | 2e 0d 0d 48 49 53 54 4f |s folder|...HISTO|
|00000f60| 52 59 0d 0d 34 2f 32 35 | 2f 38 39 09 50 72 65 65 |RY..4/25|/89.Pree|
|00000f70| 74 69 20 61 6e 64 20 44 | 65 6e 69 73 0d 36 2f 31 |ti and D|enis.6/1|
|00000f80| 38 2f 38 39 09 44 65 6e | 69 73 20 61 64 64 65 64 |8/89.Den|is added|
|00000f90| 20 6e 75 6d 65 72 69 63 | 61 6c 20 64 69 73 70 6c | numeric|al displ|
|00000fa0| 61 79 20 6f 66 20 63 6c | 75 74 20 69 6e 64 65 78 |ay of cl|ut index|
|00000fb0| 20 61 6e 64 20 74 72 69 | 70 6c 65 20 67 72 61 74 | and tri|ple grat|
|00000fc0| 69 6e 67 20 66 6f 72 20 | 66 69 72 73 74 20 73 63 |ing for |first sc|
|00000fd0| 72 65 65 6e 2e 0d 38 2f | 34 2f 38 39 09 44 65 6e |reen..8/|4/89.Den|
|00000fe0| 69 73 20 72 65 70 6c 61 | 63 65 64 20 53 65 74 45 |is repla|ced SetE|
|00000ff0| 6e 74 72 69 65 73 20 63 | 61 6c 6c 20 62 79 20 47 |ntries c|all by G|
|00001000| 44 53 65 74 45 6e 74 72 | 69 65 73 2c 20 61 6e 64 |DSetEntr|ies, and|
|00001010| 20 67 65 6e 65 72 61 6c | 6c 79 20 75 70 64 61 74 | general|ly updat|
|00001020| 65 64 20 65 76 65 72 79 | 74 68 69 6e 67 2e 0d 38 |ed every|thing..8|
|00001030| 2f 31 38 2f 38 39 09 4c | 61 6e 20 4d 65 61 73 75 |/18/89.L|an Measu|
|00001040| 72 65 20 74 68 65 20 77 | 68 6f 6c 65 20 72 6f 75 |re the w|hole rou|
|00001050| 74 69 6e 65 28 52 2b 47 | 2b 42 20 61 6e 64 20 52 |tine(R+G|+B and R|
|00001060| 20 47 20 42 20 67 61 69 | 6e 29 20 34 30 20 74 69 | G B gai|n) 40 ti|
|00001070| 6d 65 73 20 74 6f 20 65 | 6c 69 6d 69 6e 61 74 65 |mes to e|liminate|
|00001080| 20 74 68 65 0d 09 09 65 | 66 66 65 63 74 20 6f 66 | the...e|ffect of|
|00001090| 20 73 63 72 65 65 6e 20 | 6c 75 6d 69 6e 61 6e 63 | screen |luminanc|
|000010a0| 65 20 64 72 69 66 74 2e | 0d 39 2f 38 2f 38 39 09 |e drift.|.9/8/89.|
|000010b0| 4c 61 6e 20 26 20 44 65 | 6e 69 73 20 67 65 6e 65 |Lan & De|nis gene|
|000010c0| 72 61 6c 6c 79 20 74 69 | 64 69 65 64 20 69 74 20 |rally ti|died it |
|000010d0| 75 70 2e 0d 39 2f 38 2f | 38 39 09 64 65 6e 69 73 |up..9/8/|89.denis|
|000010e0| 3a 20 72 65 70 6c 61 63 | 65 64 20 70 6f 6c 79 6e |: replac|ed polyn|
|000010f0| 6f 6d 69 61 6c 20 66 69 | 74 20 62 79 20 70 6f 77 |omial fi|t by pow|
|00001100| 65 72 6c 61 77 20 66 69 | 74 0d 39 2f 31 30 2f 38 |erlaw fi|t.9/10/8|
|00001110| 39 20 64 65 6e 69 73 3a | 20 67 6f 74 20 67 61 69 |9 denis:| got gai|
|00001120| 6e 20 6d 65 61 73 75 72 | 65 6d 65 6e 74 20 74 6f |n measur|ement to|
|00001130| 20 77 6f 72 6b 20 77 69 | 74 68 20 73 75 66 66 69 | work wi|th suffi|
|00001140| 63 69 65 6e 74 20 61 63 | 63 75 72 61 63 79 2e 20 |cient ac|curacy. |
|00001150| 0d 09 09 54 68 69 73 20 | 69 6e 76 6f 6c 76 65 64 |...This |involved|
|00001160| 20 6d 61 6e 79 20 73 6d | 61 6c 6c 20 63 68 61 6e | many sm|all chan|
|00001170| 67 65 73 2e 20 49 20 6e | 6f 77 0d 09 09 77 61 69 |ges. I n|ow...wai|
|00001180| 74 20 66 6f 72 20 61 20 | 73 65 63 6f 6e 64 20 61 |t for a |second a|
|00001190| 66 74 65 72 20 61 6e 79 | 20 6c 61 72 67 65 20 6c |fter any| large l|
|000011a0| 75 6d 69 6e 61 6e 63 65 | 20 63 68 61 6e 67 65 20 |uminance| change |
|000011b0| 74 6f 20 61 6c 6c 6f 77 | 20 74 68 65 0d 09 09 70 |to allow| the...p|
|000011c0| 68 6f 74 6f 6d 65 74 65 | 72 20 74 6f 20 73 65 74 |hotomete|r to set|
|000011d0| 74 6c 65 2e 20 49 20 61 | 6c 73 6f 20 6d 65 61 73 |tle. I a|lso meas|
|000011e0| 75 72 65 20 74 68 65 20 | 63 68 61 6e 6e 65 6c 20 |ure the |channel |
|000011f0| 67 61 69 6e 73 20 61 74 | 20 6d 61 6e 79 20 64 69 |gains at| many di|
|00001200| 66 66 65 72 65 6e 74 0d | 09 09 73 65 74 74 69 6e |fferent.|..settin|
|00001210| 67 73 20 6f 66 20 74 68 | 65 20 6f 74 68 65 72 20 |gs of th|e other |
|00001220| 44 41 43 73 2c 20 69 6e | 20 6f 72 64 65 72 20 74 |DACs, in| order t|
|00001230| 6f 20 61 76 65 72 61 67 | 65 20 6f 75 74 20 74 68 |o averag|e out th|
|00001240| 65 20 65 66 66 65 63 74 | 20 6f 66 20 44 41 43 0d |e effect| of DAC.|
|00001250| 09 09 69 6e 61 63 63 75 | 72 61 63 69 65 73 2e 0d |..inaccu|racies..|
|00001260| 31 30 2f 33 30 2f 38 39 | 20 4c 61 6e 20 26 20 44 |10/30/89| Lan & D|
|00001270| 65 6e 69 73 3a 20 69 6e | 74 72 6f 64 75 63 65 64 |enis: in|troduced|
|00001280| 20 74 68 65 20 6f 70 74 | 69 6f 6e 20 6f 66 20 6d | the opt|ion of m|
|00001290| 61 6e 75 61 6c 20 72 65 | 61 64 69 6e 67 73 2c 20 |anual re|adings, |
|000012a0| 61 6e 64 20 6d 61 64 65 | 20 63 6f 6e 73 6f 6c 65 |and made| console|
|000012b0| 20 73 6d 61 6c 6c 65 72 | 2e 0d 31 31 2f 31 37 2f | smaller|..11/17/|
|000012c0| 38 39 20 4c 61 6e 20 26 | 20 44 65 6e 69 73 3a 20 |89 Lan &| Denis: |
|000012d0| 63 6c 65 61 6e 65 64 20 | 75 70 20 66 6f 72 20 67 |cleaned |up for g|
|000012e0| 65 6e 65 72 61 6c 20 72 | 65 6c 65 61 73 65 2e 0d |eneral r|elease..|
|000012f0| 31 31 2f 33 30 2f 38 39 | 20 44 65 6e 69 73 3a 20 |11/30/89| Denis: |
|00001300| 61 64 64 65 64 20 63 6f | 6d 6d 65 6e 74 20 74 6f |added co|mment to|
|00001310| 20 4c 75 6d 69 6e 61 6e | 63 65 52 65 63 6f 72 64 | Luminan|ceRecord|
|00001320| 2e 68 20 65 78 70 6c 61 | 69 6e 69 6e 67 20 70 6f |.h expla|ining po|
|00001330| 77 65 72 5b 5d 20 70 61 | 72 61 6d 65 74 65 72 73 |wer[] pa|rameters|
|00001340| 2e 0d 33 2f 32 39 2f 39 | 30 09 64 67 70 09 32 2e |..3/29/9|0.dgp.2.|
|00001350| 31 35 20 55 70 64 61 74 | 65 64 20 74 6f 20 75 73 |15 Updat|ed to us|
|00001360| 65 20 6e 65 77 20 47 65 | 74 56 6f 6c 74 61 67 65 |e new Ge|tVoltage|
|00001370| 20 74 68 61 74 20 6c 6f | 6f 6b 73 20 66 6f 72 20 | that lo|oks for |
|00001380| 46 6f 72 65 52 75 6e 6e | 65 72 20 63 61 72 64 2c |ForeRunn|er card,|
|00001390| 0d 09 09 09 61 6e 64 20 | 6e 65 77 20 47 44 4f 70 |....and |new GDOp|
|000013a0| 65 6e 57 69 6e 64 6f 77 | 28 29 20 74 68 61 74 20 |enWindow|() that |
|000013b0| 75 73 65 73 20 43 57 69 | 6e 64 6f 77 50 74 72 20 |uses CWi|ndowPtr |
|000013c0| 69 6e 73 74 65 61 64 20 | 6f 66 20 57 69 6e 64 6f |instead |of Windo|
|000013d0| 77 50 74 72 2e 20 49 6e | 74 72 6f 64 75 63 65 64 |wPtr. In|troduced|
|000013e0| 0d 09 09 09 63 6f 6e 64 | 69 74 69 6f 6e 61 6c 73 |....cond|itionals|
|000013f0| 20 73 6f 20 69 74 20 63 | 6f 6d 70 69 6c 65 73 20 | so it c|ompiles |
|00001400| 77 69 74 68 6f 75 74 20 | 65 72 72 6f 72 73 20 75 |without |errors u|
|00001410| 6e 64 65 72 20 4d 50 57 | 20 43 20 33 2e 31 2e 20 |nder MPW| C 3.1. |
|00001420| 0d 34 2f 32 31 2f 39 30 | 09 64 67 70 09 32 2e 32 |.4/21/90|.dgp.2.2|
|00001430| 30 2e 20 46 69 78 65 64 | 20 74 68 65 20 62 75 67 |0. Fixed| the bug|
|00001440| 20 69 6e 20 74 68 65 20 | 66 69 78 65 64 2d 70 6f | in the |fixed-po|
|00001450| 77 65 72 20 70 6f 77 65 | 72 20 6c 61 77 20 66 69 |wer powe|r law fi|
|00001460| 74 2e 20 55 70 64 61 74 | 65 64 20 77 68 6f 6c 65 |t. Updat|ed whole|
|00001470| 20 66 69 6c 65 0d 09 09 | 09 74 6f 20 62 65 20 63 | file...|.to be c|
|00001480| 6f 6d 70 61 74 69 62 6c | 65 20 77 69 74 68 20 6c |ompatibl|e with l|
|00001490| 61 74 65 73 74 20 76 65 | 72 73 69 6f 6e 73 20 6f |atest ve|rsions o|
|000014a0| 66 20 61 6c 6c 20 73 75 | 62 72 6f 75 74 69 6e 65 |f all su|broutine|
|000014b0| 73 2e 20 43 6f 72 72 65 | 63 74 65 64 20 70 72 69 |s. Corre|cted pri|
|000014c0| 6e 74 6f 75 74 0d 09 09 | 09 6f 66 20 6e 42 61 63 |ntout...|.of nBac|
|000014d0| 6b 67 72 6f 75 6e 64 2e | 0d 37 2f 32 38 2f 39 30 |kground.|.7/28/90|
|000014e0| 09 64 67 70 09 32 2e 33 | 2e 20 41 64 64 65 64 20 |.dgp.2.3|. Added |
|000014f0| 63 6f 64 65 20 28 69 6e | 20 47 65 74 41 4c 75 6d |code (in| GetALum|
|00001500| 69 6e 61 6e 63 65 2e 63 | 29 20 74 6f 20 66 69 6e |inance.c|) to fin|
|00001510| 64 20 74 68 65 20 65 71 | 75 69 76 61 6c 65 6e 74 |d the eq|uivalent|
|00001520| 20 6e 75 6d 62 65 72 20 | 74 6f 0d 09 09 09 70 72 | number |to....pr|
|00001530| 6f 64 75 63 65 20 61 6e | 79 20 64 65 73 69 72 65 |oduce an|y desire|
|00001540| 64 20 62 61 63 6b 67 72 | 6f 75 6e 64 20 6c 75 6d |d backgr|ound lum|
|00001550| 69 6e 61 6e 63 65 2e 0d | 09 09 09 41 6c 6c 20 6c |inance..|...All l|
|00001560| 75 6d 69 6e 61 6e 63 65 | 20 6d 65 61 73 75 72 65 |uminance| measure|
|00001570| 6d 65 6e 74 20 69 73 20 | 6e 6f 77 20 64 6f 6e 65 |ment is |now done|
|00001580| 20 76 69 61 20 74 68 65 | 20 6e 65 77 20 73 75 62 | via the| new sub|
|00001590| 72 6f 75 74 69 6e 65 20 | 47 65 74 41 4c 75 6d 69 |routine |GetALumi|
|000015a0| 6e 61 6e 63 65 2e 20 0d | 09 09 09 41 75 74 6f 6d |nance. .|...Autom|
|000015b0| 61 74 69 63 20 61 6e 64 | 20 6d 61 6e 75 61 6c 20 |atic and| manual |
|000015c0| 6d 65 61 73 75 72 65 6d | 65 6e 74 73 20 6e 6f 77 |measurem|ents now|
|000015d0| 20 75 73 65 20 74 68 65 | 20 65 78 61 63 74 6c 79 | use the| exactly|
|000015e0| 20 74 68 65 20 73 61 6d | 65 20 63 6f 64 65 2e 0d | the sam|e code..|
|000015f0| 09 09 09 43 61 6c 69 62 | 72 61 74 69 6f 6e 20 6f |...Calib|ration o|
|00001600| 66 20 28 6c 69 6e 65 61 | 72 29 20 52 47 42 20 67 |f (linea|r) RGB g|
|00001610| 61 69 6e 73 20 69 73 20 | 6e 6f 77 20 6f 70 74 69 |ains is |now opti|
|00001620| 6f 6e 61 6c 2e 0d 39 2f | 31 38 2f 39 30 09 64 67 |onal..9/|18/90.dg|
|00001630| 70 09 32 2e 34 2e 20 43 | 68 61 6e 67 65 64 20 61 |p.2.4. C|hanged a|
|00001640| 6c 6c 20 69 6e 73 74 61 | 6e 63 65 73 20 6f 66 20 |ll insta|nces of |
|00001650| 22 76 22 20 74 6f 20 22 | 56 22 2e 20 50 65 6c 6c |"v" to "|V". Pell|
|00001660| 69 0d 09 09 09 26 20 5a | 68 61 6e 67 20 28 31 39 |i....& Z|hang (19|
|00001670| 39 31 29 20 72 65 66 65 | 72 20 74 6f 20 61 20 6e |91) refe|r to a n|
|00001680| 6f 6d 69 6e 61 6c 20 76 | 6f 6c 74 61 67 65 20 76 |ominal v|oltage v|
|00001690| 3b 20 74 68 69 73 20 66 | 69 6c 65 0d 09 09 09 6e |; this f|ile....n|
|000016a0| 6f 77 20 72 65 66 65 72 | 73 20 74 6f 20 74 68 65 |ow refer|s to the|
|000016b0| 20 22 65 71 75 69 76 61 | 6c 65 6e 74 20 6e 75 6d | "equiva|lent num|
|000016c0| 62 65 72 22 20 56 3b 20 | 74 68 65 79 20 61 72 65 |ber" V; |they are|
|000016d0| 20 72 65 6c 61 74 65 64 | 20 62 79 20 56 3d 56 4d | related| by V=VM|
|000016e0| 61 78 2a 76 2e 0d 39 2f | 32 32 2f 39 30 09 64 67 |ax*v..9/|22/90.dg|
|000016f0| 70 09 32 2e 35 2e 20 46 | 69 78 65 64 20 63 6f 73 |p.2.5. F|ixed cos|
|00001700| 6d 65 74 69 63 20 65 72 | 72 6f 72 73 20 74 68 61 |metic er|rors tha|
|00001710| 74 20 70 72 65 76 65 6e | 74 65 64 20 75 73 65 20 |t preven|ted use |
|00001720| 6f 66 20 74 68 69 73 20 | 70 72 6f 67 72 61 6d 20 |of this |program |
|00001730| 6f 6e 20 74 68 65 20 6d | 61 69 6e 0d 09 09 09 73 |on the m|ain....s|
|00001740| 63 72 65 65 6e 2e 20 54 | 68 65 20 74 72 69 63 6b |creen. T|he trick|
|00001750| 20 69 73 20 61 70 70 72 | 6f 70 72 69 61 74 65 20 | is appr|opriate |
|00001760| 75 73 65 20 6f 66 20 42 | 72 69 6e 67 54 6f 46 72 |use of B|ringToFr|
|00001770| 6f 6e 74 28 29 20 61 6e | 64 20 53 65 6e 64 42 65 |ont() an|d SendBe|
|00001780| 68 69 6e 64 28 29 0d 09 | 09 09 72 65 66 65 72 72 |hind()..|..referr|
|00001790| 69 6e 67 20 6f 6e 6c 79 | 20 74 6f 20 6d 79 20 6f |ing only| to my o|
|000017a0| 77 6e 20 77 69 6e 64 6f | 77 2e 20 54 72 79 69 6e |wn windo|w. Tryin|
|000017b0| 67 20 74 6f 20 64 6f 20 | 42 72 69 6e 67 54 6f 46 |g to do |BringToF|
|000017c0| 72 6f 6e 74 28 29 20 6f | 6e 20 74 68 65 20 63 6f |ront() o|n the co|
|000017d0| 6e 73 6f 6c 65 0d 09 09 | 09 6f 66 74 65 6e 20 63 |nsole...|.often c|
|000017e0| 61 75 73 65 64 20 61 20 | 62 75 73 20 65 72 72 6f |aused a |bus erro|
|000017f0| 72 2c 20 66 6f 72 20 6e | 6f 20 6f 62 76 69 6f 75 |r, for n|o obviou|
|00001800| 73 20 72 65 61 73 6f 6e | 2e 20 49 27 6c 6c 20 68 |s reason|. I'll h|
|00001810| 61 76 65 20 74 6f 20 61 | 73 6b 20 4d 69 6b 65 0d |ave to a|sk Mike.|
|00001820| 09 09 09 4b 61 68 6c 2e | 0d 39 2f 32 34 2f 39 30 |...Kahl.|.9/24/90|
|00001830| 09 64 67 70 09 32 2e 36 | 2e 20 41 64 64 65 64 20 |.dgp.2.6|. Added |
|00001840| 73 63 72 65 65 6e 20 74 | 6f 20 74 68 65 20 4c 75 |screen t|o the Lu|
|00001850| 6d 69 6e 61 6e 63 65 52 | 65 63 6f 72 64 2e 68 20 |minanceR|ecord.h |
|00001860| 66 69 6c 65 20 61 6e 64 | 20 61 70 70 65 6e 64 65 |file and| appende|
|00001870| 64 20 69 74 20 74 6f 0d | 09 09 09 74 68 65 20 4c |d it to.|...the L|
|00001880| 75 6d 69 6e 61 6e 63 65 | 52 65 63 6f 72 64 2e 68 |uminance|Record.h|
|00001890| 20 61 6e 64 20 2e 64 61 | 74 61 20 66 69 6c 65 6e | and .da|ta filen|
|000018a0| 61 6d 65 73 2e 20 54 68 | 69 73 20 6d 61 6b 65 73 |ames. Th|is makes|
|000018b0| 20 69 74 20 65 61 73 79 | 20 74 6f 20 63 61 6c 69 | it easy| to cali|
|000018c0| 62 72 61 74 65 0d 09 09 | 09 61 6c 6c 20 79 6f 75 |brate...|.all you|
|000018d0| 72 20 6d 6f 6e 69 74 6f | 72 73 20 61 6e 64 20 6b |r monito|rs and k|
|000018e0| 65 65 70 20 74 68 65 20 | 72 65 63 6f 72 64 73 20 |eep the |records |
|000018f0| 73 74 72 61 69 67 68 74 | 2e 0d 09 09 09 41 64 64 |straight|.....Add|
|00001900| 65 64 20 4c 52 2e 64 61 | 74 65 20 73 74 72 69 6e |ed LR.da|te strin|
|00001910| 67 2e 0d 09 09 09 4e 65 | 77 20 64 65 66 61 75 6c |g.....Ne|w defaul|
|00001920| 74 20 69 73 20 74 6f 20 | 72 65 74 61 69 6e 20 6f |t is to |retain o|
|00001930| 6c 64 20 67 61 69 6e 41 | 63 63 75 72 61 63 79 20 |ld gainA|ccuracy |
|00001940| 77 68 65 6e 20 72 67 62 | 20 67 61 69 6e 73 20 61 |when rgb| gains a|
|00001950| 72 65 20 6e 6f 74 20 72 | 65 6d 65 61 73 75 72 65 |re not r|emeasure|
|00001960| 64 2e 0d 31 30 2f 31 30 | 2f 39 30 20 64 67 70 20 |d..10/10|/90 dgp |
|00001970| 41 64 64 65 64 20 53 65 | 74 44 65 70 74 68 28 29 |Added Se|tDepth()|
|00001980| 2e 20 46 69 78 65 64 20 | 62 75 67 20 74 68 61 74 |. Fixed |bug that|
|00001990| 20 72 65 64 75 63 69 6e | 67 20 74 68 65 20 6e 75 | reducin|g the nu|
|000019a0| 6d 62 65 72 20 6f 66 20 | 66 72 61 6d 65 73 20 73 |mber of |frames s|
|000019b0| 61 6d 70 6c 65 64 0d 09 | 09 09 70 65 72 20 61 2f |ampled..|..per a/|
|000019c0| 64 20 6d 65 61 73 75 72 | 65 6d 65 6e 74 20 62 79 |d measur|ement by|
|000019d0| 20 74 68 65 20 6e 75 6d | 62 65 72 20 6f 66 20 63 | the num|ber of c|
|000019e0| 79 63 6c 65 73 2e 20 54 | 68 65 20 6e 75 6d 62 65 |ycles. T|he numbe|
|000019f0| 72 20 6f 66 20 66 72 61 | 6d 65 73 20 70 65 72 0d |r of fra|mes per.|
|00001a00| 09 09 09 6d 65 61 73 75 | 72 65 6d 65 6e 74 20 69 |...measu|rement i|
|00001a10| 73 20 6e 6f 77 20 66 69 | 78 65 64 2e 0d 31 30 2f |s now fi|xed..10/|
|00001a20| 31 32 2f 39 30 20 64 67 | 70 20 41 64 64 65 64 20 |12/90 dg|p Added |
|00001a30| 4c 52 2e 64 70 69 20 61 | 6e 64 20 4c 52 2e 48 7a |LR.dpi a|nd LR.Hz|
|00001a40| 20 74 6f 20 74 68 65 20 | 4c 75 6d 69 6e 61 6e 63 | to the |Luminanc|
|00001a50| 65 52 65 63 6f 72 64 3f | 2e 68 20 66 69 6c 65 2e |eRecord?|.h file.|
|00001a60| 0d 31 30 2f 31 37 2f 39 | 30 20 64 67 70 20 52 65 |.10/17/9|0 dgp Re|
|00001a70| 6d 6f 76 65 64 20 75 6e | 75 73 65 64 20 76 61 72 |moved un|used var|
|00001a80| 69 61 62 6c 65 73 2e 20 | 41 64 64 65 64 20 72 65 |iables. |Added re|
|00001a90| 66 65 72 65 6e 63 65 20 | 74 6f 20 70 61 70 65 72 |ference |to paper|
|00001aa0| 20 74 6f 20 4c 75 6d 69 | 6e 61 6e 63 65 52 65 63 | to Lumi|nanceRec|
|00001ab0| 6f 72 64 3f 2e 68 2e 0d | 31 32 2f 31 32 2f 39 30 |ord?.h..|12/12/90|
|00001ac0| 20 64 67 70 20 4d 65 61 | 73 75 72 65 20 61 6e 64 | dgp Mea|sure and|
|00001ad0| 20 73 75 62 74 72 61 63 | 74 20 6f 66 66 20 74 68 | subtrac|t off th|
|00001ae0| 65 20 64 61 72 6b 20 76 | 6f 6c 74 61 67 65 2e 0d |e dark v|oltage..|
|00001af0| 09 09 09 46 69 78 65 64 | 20 64 75 6d 62 20 65 72 |...Fixed| dumb er|
|00001b00| 72 6f 72 20 6f 66 20 61 | 73 73 75 6d 69 6e 67 20 |ror of a|ssuming |
|00001b10| 77 72 6f 6e 67 20 74 79 | 70 65 20 77 68 65 6e 20 |wrong ty|pe when |
|00001b20| 70 72 69 6e 74 69 6e 67 | 20 4c 50 2d 3e 56 4d 61 |printing| LP->VMa|
|00001b30| 78 0d 09 09 09 26 20 4c | 50 2d 3e 63 6f 65 66 66 |x....& L|P->coeff|
|00001b40| 69 63 69 65 6e 74 73 2c | 20 77 68 69 63 68 20 77 |icients,| which w|
|00001b50| 61 73 20 72 65 73 75 6c | 74 69 6e 67 20 69 6e 20 |as resul|ting in |
|00001b60| 7a 65 72 6f 65 73 20 69 | 6e 20 74 68 65 20 4c 75 |zeroes i|n the Lu|
|00001b70| 6d 69 6e 61 6e 63 65 52 | 65 63 6f 72 64 2e 0d 34 |minanceR|ecord..4|
|00001b80| 2f 31 35 2f 39 31 09 64 | 67 70 20 43 68 65 63 6b |/15/91.d|gp Check|
|00001b90| 20 66 6f 72 20 4e 65 77 | 50 61 6c 65 74 74 65 4d | for New|PaletteM|
|00001ba0| 61 6e 61 67 65 72 28 29 | 2e 0d 38 2f 32 34 2f 39 |anager()|..8/24/9|
|00001bb0| 31 09 64 67 70 09 6d 61 | 64 65 20 63 6f 6d 70 61 |1.dgp.ma|de compa|
|00001bc0| 74 69 62 6c 65 20 77 69 | 74 68 20 54 48 49 4e 4b |tible wi|th THINK|
|00001bd0| 20 43 20 35 2e 20 54 68 | 69 73 20 72 65 71 75 69 | C 5. Th|is requi|
|00001be0| 72 65 64 20 69 6e 74 72 | 6f 64 75 63 69 6e 67 20 |red intr|oducing |
|00001bf0| 73 65 76 65 72 61 6c 0d | 09 09 09 63 61 73 74 73 |several.|...casts|
|00001c00| 3a 20 28 75 6e 73 69 67 | 6e 65 64 20 6c 6f 6e 67 |: (unsig|ned long|
|00001c10| 20 2a 29 20 61 6e 64 20 | 28 75 6e 73 69 67 6e 65 | *) and |(unsigne|
|00001c20| 64 20 63 68 61 72 20 2a | 29 2e 20 48 6f 70 65 66 |d char *|). Hopef|
|00001c30| 75 6c 6c 79 2c 20 74 68 | 69 73 20 77 6f 6e 27 74 |ully, th|is won't|
|00001c40| 0d 09 09 09 63 6f 6d 70 | 72 6f 6d 69 73 65 20 63 |....comp|romise c|
|00001c50| 6f 6d 70 61 74 69 62 69 | 6c 69 74 79 20 77 69 74 |ompatibi|lity wit|
|00001c60| 68 20 6f 6c 64 20 54 48 | 49 4e 4b 20 43 20 34 2e |h old TH|INK C 4.|
|00001c70| 0d 33 2f 31 30 2f 39 32 | 09 64 67 70 09 69 6e 63 |.3/10/92|.dgp.inc|
|00001c80| 6c 75 64 65 20 6d 63 36 | 38 38 38 31 2e 68 0d 36 |lude mc6|8881.h.6|
|00001c90| 2f 32 33 2f 39 32 09 64 | 67 70 09 61 64 64 65 64 |/23/92.d|gp.added|
|00001ca0| 20 71 75 69 63 6b 20 63 | 68 65 63 6b 20 6f 66 20 | quick c|heck of |
|00001cb0| 70 68 6f 74 6f 6d 65 74 | 65 72 20 67 61 69 6e 2e |photomet|er gain.|
|00001cc0| 0d 38 2f 32 37 2f 39 32 | 09 64 67 70 09 72 65 70 |.8/27/92|.dgp.rep|
|00001cd0| 6c 61 63 65 20 53 79 73 | 45 6e 76 69 72 6f 6e 73 |lace Sys|Environs|
|00001ce0| 28 29 20 62 79 20 47 65 | 73 74 61 6c 74 28 29 0d |() by Ge|stalt().|
|00001cf0| 31 30 2f 32 33 2f 39 32 | 20 64 67 70 20 72 65 61 |10/23/92| dgp rea|
|00001d00| 64 20 6c 61 74 65 73 74 | 20 4c 75 6d 69 6e 61 6e |d latest| Luminan|
|00001d10| 63 65 52 65 63 6f 72 64 | 20 66 6f 72 20 64 65 66 |ceRecord| for def|
|00001d20| 61 75 6c 74 20 76 61 6c | 75 65 73 2e 20 4d 65 6e |ault val|ues. Men|
|00001d30| 74 69 6f 6e 65 64 20 52 | 65 61 64 4c 75 6d 69 6e |tioned R|eadLumin|
|00001d40| 61 6e 63 65 52 65 63 6f | 72 64 28 29 0d 09 09 09 |anceReco|rd()....|
|00001d50| 69 6e 20 74 68 65 20 4c | 75 6d 69 6e 61 6e 63 65 |in the L|uminance|
|00001d60| 52 65 63 6f 72 64 20 68 | 65 61 64 65 72 20 66 69 |Record h|eader fi|
|00001d70| 6c 65 2e 0d 31 30 2f 32 | 34 2f 39 32 20 64 67 70 |le..10/2|4/92 dgp|
|00001d80| 20 75 73 65 20 47 44 46 | 72 61 6d 65 52 61 74 65 | use GDF|rameRate|
|00001d90| 28 29 20 74 6f 20 6d 65 | 61 73 75 72 65 20 74 68 |() to me|asure th|
|00001da0| 65 20 66 72 61 6d 65 20 | 72 61 74 65 2e 0d 31 31 |e frame |rate..11|
|00001db0| 2f 31 33 2f 39 32 20 64 | 67 70 20 61 64 76 65 72 |/13/92 d|gp adver|
|00001dc0| 74 69 73 65 20 52 65 61 | 64 4c 75 6d 69 6e 61 6e |tise Rea|dLuminan|
|00001dd0| 63 65 52 65 63 6f 72 64 | 2e 63 0d 31 32 2f 31 37 |ceRecord|.c.12/17|
|00001de0| 2f 39 32 20 64 67 70 20 | 45 6e 68 61 6e 63 65 64 |/92 dgp |Enhanced|
|00001df0| 20 74 6f 20 73 75 70 70 | 6f 72 74 20 61 72 62 69 | to supp|ort arbi|
|00001e00| 74 72 61 72 79 20 64 61 | 63 53 69 7a 65 2e 20 47 |trary da|cSize. G|
|00001e10| 65 74 20 64 61 63 53 69 | 7a 65 20 62 79 20 63 61 |et dacSi|ze by ca|
|00001e20| 6c 6c 69 6e 67 20 47 44 | 47 65 74 47 61 6d 6d 61 |lling GD|GetGamma|
|00001e30| 28 29 2e 20 0d 09 09 09 | 4d 6f 73 74 6c 79 20 49 |(). ....|Mostly I|
|00001e40| 20 6a 75 73 74 20 72 65 | 70 6c 61 63 65 64 20 32 | just re|placed 2|
|00001e50| 35 35 20 62 79 20 4c 50 | 2d 3e 56 4d 61 78 2e 20 |55 by LP|->VMax. |
|00001e60| 44 69 64 6e 27 74 20 74 | 65 73 74 20 69 74 20 61 |Didn't t|est it a|
|00001e70| 66 74 65 72 20 63 68 61 | 6e 67 65 73 2e 0d 31 32 |fter cha|nges..12|
|00001e80| 2f 32 31 2f 39 32 20 64 | 67 70 20 4e 6f 20 6c 6f |/21/92 d|gp No lo|
|00001e90| 6e 67 65 72 20 6c 6f 61 | 64 20 75 6e 75 73 65 64 |nger loa|d unused|
|00001ea0| 20 64 61 63 20 62 69 74 | 73 2e 0d 32 2f 32 33 2f | dac bit|s..2/23/|
|00001eb0| 39 33 09 64 67 70 09 55 | 73 65 20 6e 65 77 20 47 |93.dgp.U|se new G|
|00001ec0| 44 4f 70 65 6e 57 69 6e | 64 6f 77 31 20 61 6e 64 |DOpenWin|dow1 and|
|00001ed0| 20 47 44 44 69 73 70 6f | 73 65 57 69 6e 64 6f 77 | GDDispo|seWindow|
|00001ee0| 31 2e 0d 2a 2f 0d 23 69 | 6e 63 6c 75 64 65 20 22 |1..*/.#i|nclude "|
|00001ef0| 56 69 64 65 6f 54 6f 6f | 6c 62 6f 78 2e 68 22 0d |VideoToo|lbox.h".|
|00001f00| 23 69 6e 63 6c 75 64 65 | 20 3c 6d 61 74 68 2e 68 |#include| <math.h|
|00001f10| 3e 0d 23 69 6e 63 6c 75 | 64 65 20 22 4c 75 6d 69 |>.#inclu|de "Lumi|
|00001f20| 6e 61 6e 63 65 2e 68 22 | 0d 23 69 6e 63 6c 75 64 |nance.h"|.#includ|
|00001f30| 65 20 3c 46 6f 6e 74 73 | 2e 68 3e 0d 23 69 6e 63 |e <Fonts|.h>.#inc|
|00001f40| 6c 75 64 65 20 3c 50 61 | 63 6b 61 67 65 73 2e 68 |lude <Pa|ckages.h|
|00001f50| 3e 0d 23 69 66 20 54 48 | 49 4e 4b 5f 43 0d 09 23 |>.#if TH|INK_C..#|
|00001f60| 69 6e 63 6c 75 64 65 20 | 3c 63 6f 6e 73 6f 6c 65 |include |<console|
|00001f70| 2e 68 3e 0d 23 65 6e 64 | 69 66 0d 23 69 6e 63 6c |.h>.#end|if.#incl|
|00001f80| 75 64 65 20 3c 6e 72 2e | 68 3e 09 09 09 2f 2a 20 |ude <nr.|h>.../* |
|00001f90| 70 72 6f 74 6f 74 79 70 | 65 73 20 6f 66 20 4e 75 |prototyp|es of Nu|
|00001fa0| 6d 65 72 69 63 61 6c 20 | 52 65 63 69 70 65 73 20 |merical |Recipes |
|00001fb0| 61 6e 64 20 64 65 66 69 | 6e 69 74 69 6f 6e 20 6f |and defi|nition o|
|00001fc0| 66 20 46 4c 4f 41 54 20 | 2a 2f 0d 0d 23 64 65 66 |f FLOAT |*/..#def|
|00001fd0| 69 6e 65 20 41 55 54 4f | 4d 41 54 49 43 09 09 31 |ine AUTO|MATIC..1|
|00001fe0| 09 2f 2a 20 09 3d 30 3a | 69 6e 70 75 74 20 72 65 |./* .=0:|input re|
|00001ff0| 61 64 69 6e 67 20 62 79 | 20 68 61 6e 64 20 66 72 |ading by| hand fr|
|00002000| 6f 6d 20 74 68 65 20 70 | 68 6f 74 6f 6d 65 74 65 |om the p|hotomete|
|00002010| 72 20 74 6f 20 74 68 65 | 20 74 65 72 6d 69 6e 61 |r to the| termina|
|00002020| 6c 0d 09 09 09 09 09 09 | 09 20 20 20 09 3d 31 3a |l.......|. .=1:|
|00002030| 20 75 73 65 20 41 2f 44 | 20 63 6f 6e 76 65 72 74 | use A/D| convert|
|00002040| 65 72 20 74 6f 20 72 65 | 61 64 20 66 72 6f 6d 20 |er to re|ad from |
|00002050| 74 68 65 20 70 68 6f 74 | 6f 6d 65 74 65 72 20 64 |the phot|ometer d|
|00002060| 69 72 65 63 74 6c 79 20 | 2a 2f 0d 23 64 65 66 69 |irectly |*/.#defi|
|00002070| 6e 65 20 4e 4c 52 47 42 | 09 09 09 31 36 09 2f 2a |ne NLRGB|...16./*|
|00002080| 20 6e 75 6d 62 65 72 20 | 6f 66 20 74 69 6d 65 73 | number |of times|
|00002090| 20 74 6f 20 6d 65 61 73 | 75 72 65 20 65 61 63 68 | to meas|ure each|
|000020a0| 20 52 47 42 20 67 61 69 | 6e 2c 20 73 68 6f 75 6c | RGB gai|n, shoul|
|000020b0| 64 20 62 65 20 3e 31 2a | 2f 0d 23 64 65 66 69 6e |d be >1*|/.#defin|
|000020c0| 65 20 4c 55 4d 49 4e 41 | 4e 43 45 53 09 09 33 32 |e LUMINA|NCES..32|
|000020d0| 09 2f 2a 20 61 70 70 72 | 6f 78 2e 20 6e 75 6d 62 |./* appr|ox. numb|
|000020e0| 65 72 20 6f 66 20 64 69 | 66 66 65 72 65 6e 74 20 |er of di|fferent |
|000020f0| 6c 75 6d 69 6e 61 6e 63 | 65 73 20 74 6f 20 6d 65 |luminanc|es to me|
|00002100| 61 73 75 72 65 20 2a 2f | 0d 23 64 65 66 69 6e 65 |asure */|.#define|
|00002110| 09 4e 46 52 41 4d 45 09 | 09 09 36 30 09 2f 2a 20 |.NFRAME.|..60./* |
|00002120| 6e 75 6d 62 65 72 20 6f | 66 20 66 72 61 6d 65 73 |number o|f frames|
|00002130| 20 70 65 72 20 41 44 43 | 20 6c 75 6d 69 6e 61 6e | per ADC| luminan|
|00002140| 63 65 20 6d 65 61 73 75 | 72 65 6d 65 6e 74 20 2a |ce measu|rement *|
|00002150| 2f 0d 23 64 65 66 69 6e | 65 20 4d 41 58 5f 57 49 |/.#defin|e MAX_WI|
|00002160| 4e 44 4f 57 53 09 09 36 | 09 2f 2a 20 6d 61 78 69 |NDOWS..6|./* maxi|
|00002170| 6d 75 6d 20 6e 75 6d 62 | 65 72 20 6f 66 20 73 63 |mum numb|er of sc|
|00002180| 72 65 65 6e 73 20 74 68 | 61 74 20 79 6f 75 20 6d |reens th|at you m|
|00002190| 69 67 68 74 20 68 61 76 | 65 20 2a 2f 0d 23 64 65 |ight hav|e */.#de|
|000021a0| 66 69 6e 65 20 52 4f 55 | 4e 44 5f 4c 55 4d 49 4e |fine ROU|ND_LUMIN|
|000021b0| 41 4e 43 45 53 20 28 32 | 2b 28 32 35 36 2b 32 35 |ANCES (2|+(256+25|
|000021c0| 36 2f 4c 55 4d 49 4e 41 | 4e 43 45 53 2d 31 29 2f |6/LUMINA|NCES-1)/|
|000021d0| 28 32 35 36 2f 4c 55 4d | 49 4e 41 4e 43 45 53 29 |(256/LUM|INANCES)|
|000021e0| 29 0d 09 09 09 09 09 09 | 09 2f 2a 20 72 6f 75 6e |).......|./* roun|
|000021f0| 64 20 4c 55 4d 49 4e 41 | 4e 43 45 53 20 75 70 20 |d LUMINA|NCES up |
|00002200| 74 6f 20 74 68 65 20 6e | 65 78 74 20 64 69 76 69 |to the n|ext divi|
|00002210| 73 6f 72 20 6f 66 20 32 | 35 36 2c 20 61 64 64 20 |sor of 2|56, add |
|00002220| 32 20 2a 2f 0d 0d 76 6f | 69 64 20 6d 61 69 6e 28 |2 */..vo|id main(|
|00002230| 76 6f 69 64 29 3b 0d 76 | 6f 69 64 20 43 61 6c 69 |void);.v|oid Cali|
|00002240| 62 72 61 74 65 4c 75 6d | 69 6e 61 6e 63 65 28 76 |brateLum|inance(v|
|00002250| 6f 69 64 29 3b 0d 76 6f | 69 64 20 53 61 76 65 44 |oid);.vo|id SaveD|
|00002260| 61 74 61 28 6c 75 6d 69 | 6e 61 6e 63 65 52 65 63 |ata(lumi|nanceRec|
|00002270| 6f 72 64 20 2a 4c 50 2c | 69 6e 74 20 6e 4c 2c 69 |ord *LP,|int nL,i|
|00002280| 6e 74 20 56 5b 5d 2c 64 | 6f 75 62 6c 65 20 4c 5b |nt V[],d|ouble L[|
|00002290| 5d 0d 09 2c 69 6e 74 20 | 6e 4c 72 67 62 2c 69 6e |]..,int |nLrgb,in|
|000022a0| 74 20 6e 72 67 62 5b 33 | 5d 5b 4e 4c 52 47 42 5d |t nrgb[3|][NLRGB]|
|000022b0| 5b 33 5d 2c 64 6f 75 62 | 6c 65 20 4c 72 67 62 5b |[3],doub|le Lrgb[|
|000022c0| 33 5d 5b 4e 4c 52 47 42 | 5d 2c 64 6f 75 62 6c 65 |3][NLRGB|],double|
|000022d0| 20 67 61 69 6e 5b 33 5d | 29 3b 0d 76 6f 69 64 20 | gain[3]|);.void |
|000022e0| 53 61 76 65 4c 75 6d 69 | 6e 61 6e 63 65 52 65 63 |SaveLumi|nanceRec|
|000022f0| 6f 72 64 28 6c 75 6d 69 | 6e 61 6e 63 65 52 65 63 |ord(lumi|nanceRec|
|00002300| 6f 72 64 20 2a 4c 50 29 | 3b 0d 46 4c 4f 41 54 20 |ord *LP)|;.FLOAT |
|00002310| 50 6f 77 65 72 52 4d 53 | 45 72 72 6f 72 28 46 4c |PowerRMS|Error(FL|
|00002320| 4f 41 54 20 70 5b 5d 29 | 3b 0d 64 6f 75 62 6c 65 |OAT p[])|;.double|
|00002330| 20 47 65 74 41 4c 75 6d | 69 6e 61 6e 63 65 28 6c | GetALum|inance(l|
|00002340| 75 6d 69 6e 61 6e 63 65 | 52 65 63 6f 72 64 20 2a |uminance|Record *|
|00002350| 4c 50 2c 47 44 48 61 6e | 64 6c 65 20 64 65 76 69 |LP,GDHan|dle devi|
|00002360| 63 65 2c 0d 09 69 6e 74 | 20 66 72 61 6d 65 73 2c |ce,..int| frames,|
|00002370| 64 6f 75 62 6c 65 20 4c | 75 6d 69 6e 61 6e 63 65 |double L|uminance|
|00002380| 50 65 72 56 6f 6c 74 61 | 67 65 2c 69 6e 74 20 65 |PerVolta|ge,int e|
|00002390| 6e 74 72 79 2c 69 6e 74 | 20 72 65 64 2c 69 6e 74 |ntry,int| red,int|
|000023a0| 20 67 72 65 65 6e 2c 69 | 6e 74 20 62 6c 75 65 29 | green,i|nt blue)|
|000023b0| 3b 0d 76 6f 69 64 20 4c | 54 6f 56 48 75 6e 74 28 |;.void L|ToVHunt(|
|000023c0| 6c 75 6d 69 6e 61 6e 63 | 65 52 65 63 6f 72 64 20 |luminanc|eRecord |
|000023d0| 2a 4c 50 2c 47 44 48 61 | 6e 64 6c 65 20 64 65 76 |*LP,GDHa|ndle dev|
|000023e0| 69 63 65 2c 43 57 69 6e | 64 6f 77 50 74 72 20 77 |ice,CWin|dowPtr w|
|000023f0| 69 6e 64 6f 77 2c 0d 09 | 64 6f 75 62 6c 65 20 4c |indow,..|double L|
|00002400| 75 6d 69 6e 61 6e 63 65 | 50 65 72 56 6f 6c 74 61 |uminance|PerVolta|
|00002410| 67 65 2c 69 6e 74 20 66 | 72 61 6d 65 73 2c 64 6f |ge,int f|rames,do|
|00002420| 75 62 6c 65 20 64 61 72 | 6b 4c 75 6d 69 6e 61 6e |uble dar|kLuminan|
|00002430| 63 65 29 3b 0d 0d 2f 2a | 20 54 68 65 73 65 20 76 |ce);../*| These v|
|00002440| 61 72 69 61 62 6c 65 73 | 20 61 72 65 20 6f 75 74 |ariables| are out|
|00002450| 20 68 65 72 65 2c 20 61 | 73 20 67 6c 6f 62 61 6c | here, a|s global|
|00002460| 73 2c 20 73 6f 20 74 68 | 61 74 20 50 6f 77 65 72 |s, so th|at Power|
|00002470| 52 4d 53 45 72 72 6f 72 | 20 63 61 6e 20 61 63 63 |RMSError| can acc|
|00002480| 65 73 73 20 74 68 65 6d | 20 64 69 72 65 63 74 6c |ess them| directl|
|00002490| 79 20 2a 2f 0d 73 74 61 | 74 69 63 20 69 6e 74 20 |y */.sta|tic int |
|000024a0| 6e 4c 3d 52 4f 55 4e 44 | 5f 4c 55 4d 49 4e 41 4e |nL=ROUND|_LUMINAN|
|000024b0| 43 45 53 3b 0d 73 74 61 | 74 69 63 20 64 6f 75 62 |CES;.sta|tic doub|
|000024c0| 6c 65 20 4c 5b 52 4f 55 | 4e 44 5f 4c 55 4d 49 4e |le L[ROU|ND_LUMIN|
|000024d0| 41 4e 43 45 53 5d 3b 09 | 2f 2a 20 6c 75 6d 69 6e |ANCES];.|/* lumin|
|000024e0| 61 6e 63 65 20 61 74 20 | 56 5b 69 5d 20 2a 2f 0d |ance at |V[i] */.|
|000024f0| 73 74 61 74 69 63 20 69 | 6e 74 20 56 5b 52 4f 55 |static i|nt V[ROU|
|00002500| 4e 44 5f 4c 55 4d 49 4e | 41 4e 43 45 53 5d 3b 0d |ND_LUMIN|ANCES];.|
|00002510| 73 74 61 74 69 63 20 69 | 6e 74 20 76 61 72 69 61 |static i|nt varia|
|00002520| 62 6c 65 73 3d 34 3b 0d | 73 74 61 74 69 63 20 46 |bles=4;.|static F|
|00002530| 4c 4f 41 54 20 2a 70 3b | 0d 0d 76 6f 69 64 20 43 |LOAT *p;|..void C|
|00002540| 61 6c 69 62 72 61 74 65 | 4c 75 6d 69 6e 61 6e 63 |alibrate|Luminanc|
|00002550| 65 28 76 6f 69 64 29 3b | 0d 0d 76 6f 69 64 20 6d |e(void);|..void m|
|00002560| 61 69 6e 28 76 6f 69 64 | 29 0d 7b 0d 09 52 65 71 |ain(void|).{..Req|
|00002570| 75 69 72 65 28 67 65 73 | 74 61 6c 74 38 42 69 74 |uire(ges|talt8Bit|
|00002580| 51 44 29 3b 0d 09 43 61 | 6c 69 62 72 61 74 65 4c |QD);..Ca|librateL|
|00002590| 75 6d 69 6e 61 6e 63 65 | 28 29 3b 0d 7d 0d 0d 76 |uminance|();.}..v|
|000025a0| 6f 69 64 20 43 61 6c 69 | 62 72 61 74 65 4c 75 6d |oid Cali|brateLum|
|000025b0| 69 6e 61 6e 63 65 28 76 | 6f 69 64 29 0d 7b 0d 09 |inance(v|oid).{..|
|000025c0| 69 6e 74 20 65 72 72 6f | 72 3b 0d 09 6c 6f 6e 67 |int erro|r;..long|
|000025d0| 20 76 61 6c 75 65 3b 0d | 09 69 6e 74 20 69 2c 6a | value;.|.int i,j|
|000025e0| 2c 6b 2c 69 69 3b 0d 09 | 73 74 61 74 69 63 20 63 |,k,ii;..|static c|
|000025f0| 68 61 72 20 73 74 72 69 | 6e 67 5b 31 30 30 5d 3b |har stri|ng[100];|
|00002600| 0d 09 73 74 61 74 69 63 | 20 52 65 63 74 20 6d 79 |..static| Rect my|
|00002610| 52 65 63 74 2c 54 65 73 | 74 52 65 63 74 2c 6c 61 |Rect,Tes|tRect,la|
|00002620| 62 65 6c 52 65 63 74 3b | 0d 09 69 6e 74 20 62 6f |belRect;|..int bo|
|00002630| 74 74 6f 6d 3b 0d 09 47 | 44 48 61 6e 64 6c 65 20 |ttom;..G|DHandle |
|00002640| 64 65 76 69 63 65 20 3d | 20 4e 55 4c 4c 2c 6f 6c |device =| NULL,ol|
|00002650| 64 44 65 76 69 63 65 20 | 3d 20 4e 55 4c 4c 3b 0d |dDevice |= NULL;.|
|00002660| 09 57 69 6e 64 6f 77 50 | 74 72 20 77 69 6e 64 6f |.WindowP|tr windo|
|00002670| 77 3d 4e 55 4c 4c 2c 6f | 6c 64 57 69 6e 64 6f 77 |w=NULL,o|ldWindow|
|00002680| 3d 4e 55 4c 4c 3b 0d 09 | 73 74 61 74 69 63 20 57 |=NULL;..|static W|
|00002690| 69 6e 64 6f 77 50 74 72 | 20 77 69 6e 64 6f 77 73 |indowPtr| windows|
|000026a0| 5b 4d 41 58 5f 57 49 4e | 44 4f 57 53 5d 3b 0d 09 |[MAX_WIN|DOWS];..|
|000026b0| 73 68 6f 72 74 20 69 6e | 74 20 46 6f 6e 74 4e 75 |short in|t FontNu|
|000026c0| 6d 3b 0d 09 69 6e 74 20 | 6e 4c 72 67 62 3d 4e 4c |m;..int |nLrgb=NL|
|000026d0| 52 47 42 3b 0d 09 69 6e | 74 20 73 63 72 65 65 6e |RGB;..in|t screen|
|000026e0| 3b 0d 09 73 74 61 74 69 | 63 20 64 6f 75 62 6c 65 |;..stati|c double|
|000026f0| 20 4c 72 67 62 5b 33 5d | 5b 4e 4c 52 47 42 5d 3b | Lrgb[3]|[NLRGB];|
|00002700| 0d 09 73 74 61 74 69 63 | 20 69 6e 74 20 6e 72 67 |..static| int nrg|
|00002710| 62 5b 33 5d 5b 4e 4c 52 | 47 42 5d 5b 33 5d 3b 0d |b[3][NLR|GB][3];.|
|00002720| 09 73 74 61 74 69 63 20 | 64 6f 75 62 6c 65 20 67 |.static |double g|
|00002730| 61 69 6e 5b 33 5d 3b 0d | 09 73 74 61 74 69 63 20 |ain[3];.|.static |
|00002740| 64 6f 75 62 6c 65 20 4c | 75 6d 69 6e 61 6e 63 65 |double L|uminance|
|00002750| 50 65 72 56 6f 6c 74 61 | 67 65 3d 31 30 30 30 2e |PerVolta|ge=1000.|
|00002760| 30 3b 0d 09 73 74 61 74 | 69 63 20 6c 75 6d 69 6e |0;..stat|ic lumin|
|00002770| 61 6e 63 65 52 65 63 6f | 72 64 20 4c 52 2c 2a 4c |anceReco|rd LR,*L|
|00002780| 50 3b 0d 09 73 74 61 74 | 69 63 20 64 6f 75 62 6c |P;..stat|ic doubl|
|00002790| 65 20 2a 78 2c 2a 79 2c | 2a 73 69 67 3b 09 09 09 |e *x,*y,|*sig;...|
|000027a0| 09 09 09 2f 2a 20 66 6f | 72 20 70 6f 6c 79 6e 6f |.../* fo|r polyno|
|000027b0| 6d 69 61 6c 20 66 69 74 | 20 2a 2f 0d 09 73 74 61 |mial fit| */..sta|
|000027c0| 74 69 63 20 46 4c 4f 41 | 54 20 2a 61 2c 2a 2a 75 |tic FLOA|T *a,**u|
|000027d0| 2c 2a 2a 76 2c 2a 77 2c | 2a 2a 63 76 6d 2c 63 68 |,**v,*w,|**cvm,ch|
|000027e0| 69 73 71 3b 09 09 09 2f | 2a 20 66 6f 72 20 70 6f |isq;.../|* for po|
|000027f0| 6c 79 6e 6f 6d 69 61 6c | 20 66 69 74 20 2a 2f 0d |lynomial| fit */.|
|00002800| 09 69 6e 74 20 6d 61 3b | 09 09 09 09 09 09 09 09 |.int ma;|........|
|00002810| 09 09 09 2f 2a 20 66 6f | 72 20 70 6f 6c 79 6e 6f |.../* fo|r polyno|
|00002820| 6d 69 61 6c 20 66 69 74 | 20 2a 2f 0d 09 73 74 61 |mial fit| */..sta|
|00002830| 74 69 63 20 46 4c 4f 41 | 54 20 2a 2a 78 69 2c 66 |tic FLOA|T **xi,f|
|00002840| 74 6f 6c 2c 66 72 65 74 | 3b 09 09 09 09 09 2f 2a |tol,fret|;...../*|
|00002850| 20 66 6f 72 20 70 6f 77 | 65 72 20 6c 61 77 20 66 | for pow|er law f|
|00002860| 69 74 20 2a 2f 0d 09 69 | 6e 74 20 69 74 65 72 3b |it */..i|nt iter;|
|00002870| 09 09 09 09 09 09 09 09 | 09 09 2f 2a 20 66 6f 72 |........|../* for|
|00002880| 20 70 6f 77 65 72 20 6c | 61 77 20 66 69 74 20 2a | power l|aw fit *|
|00002890| 2f 0d 09 73 74 61 74 69 | 63 20 64 6f 75 62 6c 65 |/..stati|c double|
|000028a0| 20 65 2c 66 2c 56 56 3b | 0d 09 69 6e 74 20 63 74 | e,f,VV;|..int ct|
|000028b0| 53 69 7a 65 3b 0d 09 69 | 6e 74 20 72 65 61 64 4e |Size;..i|nt readN|
|000028c0| 75 6d 62 65 72 2c 72 65 | 61 64 54 6f 74 61 6c 3b |umber,re|adTotal;|
|000028d0| 0d 09 42 6f 6f 6c 65 61 | 6e 20 66 6c 61 67 3b 0d |..Boolea|n flag;.|
|000028e0| 09 73 68 6f 72 74 20 69 | 6e 74 20 74 65 73 74 53 |.short i|nt testS|
|000028f0| 69 7a 65 2c 63 79 63 6c | 65 73 2c 74 65 78 74 53 |ize,cycl|es,textS|
|00002900| 69 7a 65 3b 0d 09 42 6f | 6f 6c 65 61 6e 20 61 75 |ize;..Bo|olean au|
|00002910| 74 6f 6d 61 74 69 63 2c | 73 6b 69 70 52 47 42 3b |tomatic,|skipRGB;|
|00002920| 0d 09 63 68 61 72 20 6d | 79 43 68 61 72 3b 0d 09 |..char m|yChar;..|
|00002930| 69 6e 74 20 66 72 61 6d | 65 73 3b 0d 09 64 6f 75 |int fram|es;..dou|
|00002940| 62 6c 65 20 6c 75 6d 69 | 6e 61 6e 63 65 3b 0d 09 |ble lumi|nance;..|
|00002950| 73 74 61 74 69 63 20 64 | 6f 75 62 6c 65 20 64 61 |static d|ouble da|
|00002960| 72 6b 4c 75 6d 69 6e 61 | 6e 63 65 3b 0d 09 47 61 |rkLumina|nce;..Ga|
|00002970| 6d 6d 61 54 62 6c 20 2a | 67 61 6d 6d 61 54 62 6c |mmaTbl *|gammaTbl|
|00002980| 50 74 72 3d 4e 55 4c 4c | 3b 0d 09 0d 09 61 75 74 |Ptr=NULL|;....aut|
|00002990| 6f 6d 61 74 69 63 3d 41 | 55 54 4f 4d 41 54 49 43 |omatic=A|UTOMATIC|
|000029a0| 20 26 26 20 28 43 61 72 | 64 53 6c 6f 74 28 22 2e | && (Car|dSlot(".|
|000029b0| 46 6f 72 65 52 75 6e 6e | 65 72 22 29 3e 30 29 3b |ForeRunn|er")>0);|
|000029c0| 09 2f 2a 20 64 69 73 61 | 62 6c 65 20 69 66 20 63 |./* disa|ble if c|
|000029d0| 61 72 64 20 69 73 20 6d | 69 73 73 69 6e 67 20 2a |ard is m|issing *|
|000029e0| 2f 0d 09 4c 50 3d 26 4c | 52 3b 0d 09 23 69 6e 63 |/..LP=&L|R;..#inc|
|000029f0| 6c 75 64 65 20 22 4c 75 | 6d 69 6e 61 6e 63 65 52 |lude "Lu|minanceR|
|00002a00| 65 63 6f 72 64 31 2e 68 | 22 20 09 09 09 09 09 09 |ecord1.h|" ......|
|00002a10| 2f 2a 20 67 65 74 20 64 | 65 66 61 75 6c 74 73 20 |/* get d|efaults |
|00002a20| 66 72 6f 6d 20 6f 6c 64 | 20 63 61 6c 69 62 72 61 |from old| calibra|
|00002a30| 74 69 6f 6e 20 2a 2f 0d | 09 23 69 66 20 54 48 49 |tion */.|.#if THI|
|00002a40| 4e 4b 5f 43 0d 09 09 63 | 6f 6e 73 6f 6c 65 5f 6f |NK_C...c|onsole_o|
|00002a50| 70 74 69 6f 6e 73 2e 74 | 69 74 6c 65 3d 22 5c 70 |ptions.t|itle="\p|
|00002a60| 43 61 6c 69 62 72 61 74 | 65 4c 75 6d 69 6e 61 6e |Calibrat|eLuminan|
|00002a70| 63 65 22 3b 09 2f 2a 20 | 63 68 61 6e 67 65 20 74 |ce";./* |change t|
|00002a80| 68 65 20 63 6f 6e 73 6f | 6c 65 20 77 69 6e 64 6f |he conso|le windo|
|00002a90| 77 20 2a 2f 0d 09 09 63 | 6f 6e 73 6f 6c 65 5f 6f |w */...c|onsole_o|
|00002aa0| 70 74 69 6f 6e 73 2e 6e | 72 6f 77 73 3d 31 32 3b |ptions.n|rows=12;|
|00002ab0| 0d 09 09 63 6f 6e 73 6f | 6c 65 5f 6f 70 74 69 6f |...conso|le_optio|
|00002ac0| 6e 73 2e 74 6f 70 3d 32 | 30 3b 0d 09 09 63 6f 6e |ns.top=2|0;...con|
|00002ad0| 73 6f 6c 65 5f 6f 70 74 | 69 6f 6e 73 2e 6c 65 66 |sole_opt|ions.lef|
|00002ae0| 74 3d 30 3b 0d 09 09 63 | 6f 6e 73 6f 6c 65 5f 6f |t=0;...c|onsole_o|
|00002af0| 70 74 69 6f 6e 73 2e 6e | 63 6f 6c 73 3d 31 30 35 |ptions.n|cols=105|
|00002b00| 3b 0d 09 09 63 6f 6e 73 | 6f 6c 65 5f 6f 70 74 69 |;...cons|ole_opti|
|00002b10| 6f 6e 73 2e 74 78 53 69 | 7a 65 3d 39 3b 0d 09 09 |ons.txSi|ze=9;...|
|00002b20| 70 72 69 6e 74 66 28 22 | 5c 6e 22 29 3b 09 09 09 |printf("|\n");...|
|00002b30| 09 09 09 09 09 09 2f 2a | 20 61 73 6b 20 54 48 49 |....../*| ask THI|
|00002b40| 4e 4b 20 43 20 74 6f 20 | 69 6e 69 74 69 61 6c 69 |NK C to |initiali|
|00002b50| 7a 65 20 51 75 69 63 6b | 44 72 61 77 20 2a 2f 0d |ze Quick|Draw */.|
|00002b60| 09 09 43 6f 70 79 51 75 | 69 63 6b 44 72 61 77 47 |..CopyQu|ickDrawG|
|00002b70| 6c 6f 62 61 6c 73 28 29 | 3b 09 09 09 09 09 09 09 |lobals()|;.......|
|00002b80| 2f 2f 20 4d 61 6b 65 20 | 73 75 72 65 20 71 64 20 |// Make |sure qd |
|00002b90| 69 73 20 76 61 6c 69 64 | 2e 0d 09 23 65 6c 73 65 |is valid|...#else|
|00002ba0| 0d 09 09 49 6e 69 74 47 | 72 61 66 28 26 71 64 2e |...InitG|raf(&qd.|
|00002bb0| 74 68 65 50 6f 72 74 29 | 3b 0d 09 09 49 6e 69 74 |thePort)|;...Init|
|00002bc0| 57 69 6e 64 6f 77 73 28 | 29 3b 0d 09 09 49 6e 69 |Windows(|);...Ini|
|00002bd0| 74 46 6f 6e 74 73 28 29 | 3b 0d 09 23 65 6e 64 69 |tFonts()|;..#endi|
|00002be0| 66 0d 0d 09 6f 6c 64 44 | 65 76 69 63 65 20 3d 20 |f...oldD|evice = |
|00002bf0| 47 65 74 47 44 65 76 69 | 63 65 28 29 3b 0d 09 47 |GetGDevi|ce();..G|
|00002c00| 65 74 50 6f 72 74 28 26 | 6f 6c 64 57 69 6e 64 6f |etPort(&|oldWindo|
|00002c10| 77 29 3b 0d 09 47 65 74 | 46 4e 75 6d 28 28 53 74 |w);..Get|FNum((St|
|00002c20| 72 69 6e 67 50 74 72 29 | 20 22 5c 70 43 68 69 63 |ringPtr)| "\pChic|
|00002c30| 61 67 6f 22 2c 26 46 6f | 6e 74 4e 75 6d 29 3b 0d |ago",&Fo|ntNum);.|
|00002c40| 09 66 6f 72 28 69 3d 30 | 3b 69 3c 4d 41 58 5f 57 |.for(i=0|;i<MAX_W|
|00002c50| 49 4e 44 4f 57 53 3b 69 | 2b 2b 29 7b 0d 09 09 64 |INDOWS;i|++){...d|
|00002c60| 65 76 69 63 65 20 3d 20 | 47 65 74 53 63 72 65 65 |evice = |GetScree|
|00002c70| 6e 44 65 76 69 63 65 28 | 69 29 3b 0d 09 09 69 66 |nDevice(|i);...if|
|00002c80| 28 64 65 76 69 63 65 20 | 3d 3d 20 4e 55 4c 4c 29 |(device |== NULL)|
|00002c90| 62 72 65 61 6b 3b 0d 09 | 09 77 69 6e 64 6f 77 73 |break;..|.windows|
|00002ca0| 5b 69 5d 20 3d 20 47 44 | 4f 70 65 6e 57 69 6e 64 |[i] = GD|OpenWind|
|00002cb0| 6f 77 31 28 64 65 76 69 | 63 65 29 3b 0d 09 09 53 |ow1(devi|ce);...S|
|00002cc0| 65 6e 64 42 65 68 69 6e | 64 28 77 69 6e 64 6f 77 |endBehin|d(window|
|00002cd0| 73 5b 69 5d 2c 4e 55 4c | 4c 29 3b 0d 09 09 53 65 |s[i],NUL|L);...Se|
|00002ce0| 74 50 6f 72 74 28 77 69 | 6e 64 6f 77 73 5b 69 5d |tPort(wi|ndows[i]|
|00002cf0| 29 3b 0d 09 09 54 65 78 | 74 46 6f 6e 74 28 46 6f |);...Tex|tFont(Fo|
|00002d00| 6e 74 4e 75 6d 29 3b 0d | 09 09 74 65 78 74 53 69 |ntNum);.|..textSi|
|00002d10| 7a 65 3d 31 32 38 3b 0d | 09 09 54 65 78 74 53 69 |ze=128;.|..TextSi|
|00002d20| 7a 65 28 74 65 78 74 53 | 69 7a 65 29 3b 0d 09 09 |ze(textS|ize);...|
|00002d30| 6d 79 52 65 63 74 20 3d | 20 77 69 6e 64 6f 77 73 |myRect =| windows|
|00002d40| 5b 69 5d 2d 3e 70 6f 72 | 74 52 65 63 74 3b 0d 09 |[i]->por|tRect;..|
|00002d50| 09 62 6f 74 74 6f 6d 3d | 6d 79 52 65 63 74 2e 62 |.bottom=|myRect.b|
|00002d60| 6f 74 74 6f 6d 3b 0d 09 | 09 4d 6f 76 65 54 6f 28 |ottom;..|.MoveTo(|
|00002d70| 6d 79 52 65 63 74 2e 72 | 69 67 68 74 2f 32 2c 6d |myRect.r|ight/2,m|
|00002d80| 79 52 65 63 74 2e 62 6f | 74 74 6f 6d 2f 32 29 3b |yRect.bo|ttom/2);|
|00002d90| 0d 09 09 73 70 72 69 6e | 74 66 28 73 74 72 69 6e |...sprin|tf(strin|
|00002da0| 67 2c 22 25 31 64 22 2c | 69 29 3b 0d 09 09 43 74 |g,"%1d",|i);...Ct|
|00002db0| 6f 50 73 74 72 28 73 74 | 72 69 6e 67 29 3b 0d 09 |oPstr(st|ring);..|
|00002dc0| 09 4d 6f 76 65 28 2d 53 | 74 72 69 6e 67 57 69 64 |.Move(-S|tringWid|
|00002dd0| 74 68 28 28 76 6f 69 64 | 20 2a 29 73 74 72 69 6e |th((void| *)strin|
|00002de0| 67 29 2f 32 2c 74 65 78 | 74 53 69 7a 65 2f 32 29 |g)/2,tex|tSize/2)|
|00002df0| 3b 0d 09 09 44 72 61 77 | 53 74 72 69 6e 67 28 28 |;...Draw|String((|
|00002e00| 53 74 72 69 6e 67 50 74 | 72 29 20 73 74 72 69 6e |StringPt|r) strin|
|00002e10| 67 29 3b 0d 09 7d 0d 09 | 53 65 74 50 6f 72 74 28 |g);..}..|SetPort(|
|00002e20| 6f 6c 64 57 69 6e 64 6f | 77 29 3b 0d 09 53 65 74 |oldWindo|w);..Set|
|00002e30| 47 44 65 76 69 63 65 28 | 6f 6c 64 44 65 76 69 63 |GDevice(|oldDevic|
|00002e40| 65 29 3b 0d 0d 09 70 72 | 69 6e 74 66 28 22 57 65 |e);...pr|intf("We|
|00002e50| 6c 63 6f 6d 65 20 74 6f | 20 43 61 6c 69 62 72 61 |lcome to| Calibra|
|00002e60| 74 65 4c 75 6d 69 6e 61 | 6e 63 65 20 28 76 65 72 |teLumina|nce (ver|
|00002e70| 73 69 6f 6e 20 31 32 2f | 31 37 2f 39 32 29 2e 5c |sion 12/|17/92).\|
|00002e80| 6e 5c 6e 22 0d 09 22 54 | 68 69 73 20 70 72 6f 67 |n\n".."T|his prog|
|00002e90| 72 61 6d 20 68 65 6c 70 | 73 20 79 6f 75 20 74 6f |ram help|s you to|
|00002ea0| 20 63 61 6c 69 62 72 61 | 74 65 20 79 6f 75 72 20 | calibra|te your |
|00002eb0| 49 53 52 20 56 69 64 65 | 6f 20 41 74 74 65 6e 75 |ISR Vide|o Attenu|
|00002ec0| 61 74 6f 72 2c 20 61 73 | 20 77 65 6c 6c 20 61 73 |ator, as| well as|
|00002ed0| 20 79 6f 75 72 20 76 69 | 64 65 6f 20 63 61 72 64 | your vi|deo card|
|00002ee0| 5c 6e 22 0d 09 22 61 6e | 64 20 6d 6f 6e 69 74 6f |\n".."an|d monito|
|00002ef0| 72 2e 20 27 45 6e 74 65 | 72 27 20 69 6e 64 69 63 |r. 'Ente|r' indic|
|00002f00| 61 74 65 73 20 74 68 61 | 74 20 79 6f 75 20 73 68 |ates tha|t you sh|
|00002f10| 6f 75 6c 64 20 74 79 70 | 65 20 69 6e 20 61 20 6e |ould typ|e in a n|
|00002f20| 75 6d 62 65 72 20 6f 72 | 20 6c 65 74 74 65 72 20 |umber or| letter |
|00002f30| 66 6f 6c 6c 6f 77 65 64 | 20 62 79 20 27 52 45 54 |followed| by 'RET|
|00002f40| 55 52 4e 27 2e 5c 6e 22 | 0d 09 22 4d 6f 73 74 20 |URN'.\n"|.."Most |
|00002f50| 71 75 65 73 74 69 6f 6e | 73 20 70 72 6f 76 69 64 |question|s provid|
|00002f60| 65 20 61 20 64 65 66 61 | 75 6c 74 20 61 6e 73 77 |e a defa|ult answ|
|00002f70| 65 72 20 28 69 6e 20 70 | 61 72 65 6e 74 68 65 73 |er (in p|arenthes|
|00002f80| 65 73 29 2e 5c 6e 22 0d | 09 22 4a 75 73 74 20 68 |es).\n".|."Just h|
|00002f90| 69 74 20 27 52 45 54 55 | 52 4e 27 20 69 66 20 79 |it 'RETU|RN' if y|
|00002fa0| 6f 75 20 77 61 6e 74 20 | 74 68 65 20 64 65 66 61 |ou want |the defa|
|00002fb0| 75 6c 74 2e 20 28 4f 72 | 20 68 69 74 20 43 6f 6d |ult. (Or| hit Com|
|00002fc0| 6d 61 6e 64 2d 2e 20 74 | 6f 20 71 75 69 74 2e 29 |mand-. t|o quit.)|
|00002fd0| 5c 6e 22 0d 09 22 57 68 | 65 72 65 20 61 70 70 72 |\n".."Wh|ere appr|
|00002fe0| 6f 70 72 69 61 74 65 2c | 20 74 68 65 20 64 65 66 |opriate,| the def|
|00002ff0| 61 75 6c 74 20 69 73 20 | 74 61 6b 65 6e 20 66 72 |ault is |taken fr|
|00003000| 6f 6d 20 6c 61 74 65 73 | 74 20 4c 75 6d 69 6e 61 |om lates|t Lumina|
|00003010| 6e 63 65 52 65 63 6f 72 | 64 2e 5c 6e 22 29 3b 0d |nceRecor|d.\n");.|
|00003020| 0d 09 73 63 72 65 65 6e | 3d 30 3b 0d 09 69 66 28 |..screen|=0;..if(|
|00003030| 47 65 74 53 63 72 65 65 | 6e 44 65 76 69 63 65 28 |GetScree|nDevice(|
|00003040| 4c 50 2d 3e 73 63 72 65 | 65 6e 29 20 21 3d 20 4e |LP->scre|en) != N|
|00003050| 55 4c 4c 29 09 73 63 72 | 65 65 6e 3d 4c 50 2d 3e |ULL).scr|een=LP->|
|00003060| 73 63 72 65 65 6e 3b 0d | 09 70 72 69 6e 74 66 28 |screen;.|.printf(|
|00003070| 22 5c 6e 45 6e 74 65 72 | 20 74 68 65 20 6e 75 6d |"\nEnter| the num|
|00003080| 62 65 72 20 6f 66 20 74 | 68 65 20 73 63 72 65 65 |ber of t|he scree|
|00003090| 6e 20 79 6f 75 20 77 61 | 6e 74 20 74 6f 20 63 61 |n you wa|nt to ca|
|000030a0| 6c 69 62 72 61 74 65 20 | 28 25 64 29 3a 22 2c 73 |librate |(%d):",s|
|000030b0| 63 72 65 65 6e 29 3b 0d | 09 67 65 74 73 28 73 74 |creen);.|.gets(st|
|000030c0| 72 69 6e 67 29 3b 0d 09 | 73 73 63 61 6e 66 28 73 |ring);..|sscanf(s|
|000030d0| 74 72 69 6e 67 2c 22 25 | 64 22 2c 26 73 63 72 65 |tring,"%|d",&scre|
|000030e0| 65 6e 29 3b 0d 09 70 72 | 69 6e 74 66 28 22 25 64 |en);..pr|intf("%d|
|000030f0| 5c 6e 22 2c 73 63 72 65 | 65 6e 29 3b 0d 09 66 6f |\n",scre|en);..fo|
|00003100| 72 28 69 3d 30 3b 69 3c | 4d 41 58 5f 57 49 4e 44 |r(i=0;i<|MAX_WIND|
|00003110| 4f 57 53 3b 69 2b 2b 29 | 7b 0d 09 09 64 65 76 69 |OWS;i++)|{...devi|
|00003120| 63 65 20 3d 20 47 65 74 | 53 63 72 65 65 6e 44 65 |ce = Get|ScreenDe|
|00003130| 76 69 63 65 28 69 29 3b | 0d 09 09 69 66 28 64 65 |vice(i);|...if(de|
|00003140| 76 69 63 65 20 3d 3d 20 | 4e 55 4c 4c 29 62 72 65 |vice == |NULL)bre|
|00003150| 61 6b 3b 0d 09 09 47 44 | 44 69 73 70 6f 73 65 57 |ak;...GD|DisposeW|
|00003160| 69 6e 64 6f 77 31 28 77 | 69 6e 64 6f 77 73 5b 69 |indow1(w|indows[i|
|00003170| 5d 29 3b 0d 09 7d 0d 09 | 4c 50 2d 3e 73 63 72 65 |]);..}..|LP->scre|
|00003180| 65 6e 3d 73 63 72 65 65 | 6e 3b 0d 09 73 70 72 69 |en=scree|n;..spri|
|00003190| 6e 74 66 28 73 74 72 69 | 6e 67 2c 22 4c 75 6d 69 |ntf(stri|ng,"Lumi|
|000031a0| 6e 61 6e 63 65 52 65 63 | 6f 72 64 25 64 2e 68 22 |nanceRec|ord%d.h"|
|000031b0| 2c 73 63 72 65 65 6e 29 | 3b 0d 09 69 3d 52 65 61 |,screen)|;..i=Rea|
|000031c0| 64 4c 75 6d 69 6e 61 6e | 63 65 52 65 63 6f 72 64 |dLuminan|ceRecord|
|000031d0| 28 73 74 72 69 6e 67 2c | 4c 50 2c 30 29 3b 09 09 |(string,|LP,0);..|
|000031e0| 2f 2f 20 74 72 79 20 74 | 6f 20 72 65 61 64 20 6c |// try t|o read l|
|000031f0| 61 74 65 73 74 20 6c 75 | 6d 69 6e 61 6e 63 65 52 |atest lu|minanceR|
|00003200| 65 63 6f 72 64 0d 09 69 | 66 28 69 3c 31 29 70 72 |ecord..i|f(i<1)pr|
|00003210| 69 6e 74 66 28 22 43 6f | 75 6c 64 6e 27 74 20 66 |intf("Co|uldn't f|
|00003220| 69 6e 64 20 61 6e 20 6f | 6c 64 20 63 6f 70 79 20 |ind an o|ld copy |
|00003230| 6f 66 20 d2 25 73 d3 2e | 5c 6e 22 2c 73 74 72 69 |of .%s..|\n",stri|
|00003240| 6e 67 29 3b 0d 09 65 6c | 73 65 20 70 72 69 6e 74 |ng);..el|se print|
|00003250| 66 28 22 52 65 61 64 20 | 6f 6c 64 20 d2 25 73 d3 |f("Read |old .%s.|
|00003260| 20 74 6f 20 73 65 74 20 | 64 65 66 61 75 6c 74 20 | to set |default |
|00003270| 76 61 6c 75 65 73 2e 5c | 6e 22 2c 73 74 72 69 6e |values.\|n",strin|
|00003280| 67 29 3b 0d 09 09 0d 09 | 47 65 74 50 6f 72 74 28 |g);.....|GetPort(|
|00003290| 26 6f 6c 64 57 69 6e 64 | 6f 77 29 3b 0d 09 6f 6c |&oldWind|ow);..ol|
|000032a0| 64 44 65 76 69 63 65 20 | 3d 20 47 65 74 47 44 65 |dDevice |= GetGDe|
|000032b0| 76 69 63 65 28 29 3b 0d | 09 64 65 76 69 63 65 20 |vice();.|.device |
|000032c0| 3d 20 47 65 74 53 63 72 | 65 65 6e 44 65 76 69 63 |= GetScr|eenDevic|
|000032d0| 65 28 73 63 72 65 65 6e | 29 3b 09 09 09 2f 2a 20 |e(screen|);.../* |
|000032e0| 63 68 6f 6f 73 65 20 77 | 68 69 63 68 20 73 63 72 |choose w|hich scr|
|000032f0| 65 65 6e 20 74 6f 20 74 | 65 73 74 20 2a 2f 0d 09 |een to t|est */..|
|00003300| 63 74 53 69 7a 65 3d 28 | 2a 28 2a 2a 28 2a 2a 64 |ctSize=(|*(**(**d|
|00003310| 65 76 69 63 65 29 2e 67 | 64 50 4d 61 70 29 2e 70 |evice).g|dPMap).p|
|00003320| 6d 54 61 62 6c 65 29 2d | 3e 63 74 53 69 7a 65 3b |mTable)-|>ctSize;|
|00003330| 09 09 0d 09 69 66 28 63 | 74 53 69 7a 65 3c 33 20 |....if(c|tSize<3 |
|00003340| 26 26 20 4e 65 77 50 61 | 6c 65 74 74 65 4d 61 6e |&& NewPa|letteMan|
|00003350| 61 67 65 72 28 29 29 0d | 09 09 53 65 74 44 65 70 |ager()).|..SetDep|
|00003360| 74 68 28 64 65 76 69 63 | 65 2c 38 2c 31 2c 31 29 |th(devic|e,8,1,1)|
|00003370| 3b 09 09 09 2f 2a 20 38 | 2d 62 69 74 20 70 69 78 |;.../* 8|-bit pix|
|00003380| 65 6c 53 69 7a 65 20 26 | 20 63 6f 6c 6f 72 20 6d |elSize &| color m|
|00003390| 6f 64 65 20 2a 2f 0d 09 | 63 74 53 69 7a 65 3d 28 |ode */..|ctSize=(|
|000033a0| 2a 28 2a 2a 28 2a 2a 64 | 65 76 69 63 65 29 2e 67 |*(**(**d|evice).g|
|000033b0| 64 50 4d 61 70 29 2e 70 | 6d 54 61 62 6c 65 29 2d |dPMap).p|mTable)-|
|000033c0| 3e 63 74 53 69 7a 65 3b | 09 09 0d 0d 09 2f 2f 20 |>ctSize;|.....// |
|000033d0| 47 65 74 20 64 61 63 53 | 69 7a 65 0d 09 65 72 72 |Get dacS|ize..err|
|000033e0| 6f 72 3d 47 44 47 65 74 | 47 61 6d 6d 61 28 64 65 |or=GDGet|Gamma(de|
|000033f0| 76 69 63 65 2c 26 67 61 | 6d 6d 61 54 62 6c 50 74 |vice,&ga|mmaTblPt|
|00003400| 72 29 3b 09 09 2f 2f 20 | 54 61 6b 65 73 20 32 30 |r);..// |Takes 20|
|00003410| 30 20 b5 73 2e 0d 09 69 | 66 28 65 72 72 6f 72 29 |0 .s...i|f(error)|
|00003420| 20 4c 50 2d 3e 64 61 63 | 53 69 7a 65 3d 38 3b 0d | LP->dac|Size=8;.|
|00003430| 09 65 6c 73 65 20 4c 50 | 2d 3e 64 61 63 53 69 7a |.else LP|->dacSiz|
|00003440| 65 3d 67 61 6d 6d 61 54 | 62 6c 50 74 72 2d 3e 67 |e=gammaT|blPtr->g|
|00003450| 44 61 74 61 57 69 64 74 | 68 3b 0d 09 70 72 69 6e |DataWidt|h;..prin|
|00003460| 74 66 28 22 54 68 65 20 | 76 69 64 65 6f 20 63 61 |tf("The |video ca|
|00003470| 72 64 20 68 61 73 20 25 | 64 2d 62 69 74 20 64 61 |rd has %|d-bit da|
|00003480| 63 73 2e 5c 6e 22 2c 4c | 50 2d 3e 64 61 63 53 69 |cs.\n",L|P->dacSi|
|00003490| 7a 65 29 3b 0d 0d 09 77 | 69 6e 64 6f 77 20 3d 20 |ze);...w|indow = |
|000034a0| 47 44 4f 70 65 6e 57 69 | 6e 64 6f 77 31 28 64 65 |GDOpenWi|ndow1(de|
|000034b0| 76 69 63 65 29 3b 0d 09 | 53 65 6e 64 42 65 68 69 |vice);..|SendBehi|
|000034c0| 6e 64 28 77 69 6e 64 6f | 77 2c 4e 55 4c 4c 29 3b |nd(windo|w,NULL);|
|000034d0| 0d 09 70 72 69 6e 74 66 | 28 22 54 65 73 74 20 73 |..printf|("Test s|
|000034e0| 63 72 65 65 6e 20 69 73 | 20 73 65 74 20 74 6f 20 |creen is| set to |
|000034f0| 25 64 20 63 6f 6c 6f 72 | 73 20 22 2c 63 74 53 69 |%d color|s ",ctSi|
|00003500| 7a 65 2b 31 29 3b 0d 09 | 69 66 28 63 74 53 69 7a |ze+1);..|if(ctSiz|
|00003510| 65 20 3c 33 29 20 09 7b | 0d 09 09 50 72 69 6e 74 |e <3) .{|...Print|
|00003520| 66 45 78 69 74 28 22 5c | 6e 5c 30 30 37 20 53 6f |fExit("\|n\007 So|
|00003530| 72 72 79 2e 20 59 6f 75 | 20 6e 65 65 64 20 74 6f |rry. You| need to|
|00003540| 20 73 65 74 20 74 68 65 | 20 74 65 73 74 20 73 63 | set the| test sc|
|00003550| 72 65 65 6e 20 74 6f 20 | 61 74 20 6c 65 61 73 74 |reen to |at least|
|00003560| 20 34 20 63 6f 6c 6f 72 | 73 2e 5c 6e 22 0d 09 09 | 4 color|s.\n"...|
|00003570| 09 22 48 69 74 20 27 52 | 45 54 55 52 4e 27 20 74 |."Hit 'R|ETURN' t|
|00003580| 6f 20 71 75 69 74 20 74 | 68 65 20 70 72 6f 67 72 |o quit t|he progr|
|00003590| 61 6d 20 74 68 65 6e 20 | 67 6f 20 74 6f 20 27 4d |am then |go to 'M|
|000035a0| 6f 6e 69 74 6f 72 73 27 | 20 69 6e 20 74 68 65 20 |onitors'| in the |
|000035b0| 22 0d 09 09 09 22 43 6f | 6e 74 72 6f 6c 20 50 61 |"...."Co|ntrol Pa|
|000035c0| 6e 65 6c 20 61 6e 64 20 | 73 65 74 20 74 6f 20 27 |nel and |set to '|
|000035d0| 43 6f 6c 6f 72 73 27 20 | 61 6e 64 20 27 32 35 36 |Colors' |and '256|
|000035e0| 27 5c 6e 22 29 3b 0d 09 | 7d 0d 09 47 44 47 65 74 |'\n");..|}..GDGet|
|000035f0| 47 72 61 79 28 64 65 76 | 69 63 65 2c 26 66 6c 61 |Gray(dev|ice,&fla|
|00003600| 67 29 3b 09 09 2f 2a 20 | 66 6c 61 67 3d 30 3a 63 |g);../* |flag=0:c|
|00003610| 6f 6c 6f 72 20 6d 6f 64 | 65 3b 66 6c 61 67 3d 31 |olor mod|e;flag=1|
|00003620| 3a 67 72 61 79 20 6d 6f | 64 65 20 2a 2f 0d 09 2f |:gray mo|de */../|
|00003630| 2a 20 72 65 71 75 65 73 | 74 20 63 6f 6c 6f 72 20 |* reques|t color |
|00003640| 6d 6f 64 65 20 2a 2f 0d | 09 69 66 20 28 66 6c 61 |mode */.|.if (fla|
|00003650| 67 20 21 3d 20 30 20 26 | 26 20 4e 65 77 50 61 6c |g != 0 &|& NewPal|
|00003660| 65 74 74 65 4d 61 6e 61 | 67 65 72 28 29 29 0d 09 |etteMana|ger())..|
|00003670| 09 53 65 74 44 65 70 74 | 68 28 64 65 76 69 63 65 |.SetDept|h(device|
|00003680| 2c 28 2a 2a 28 2a 2a 64 | 65 76 69 63 65 29 2e 67 |,(**(**d|evice).g|
|00003690| 64 50 4d 61 70 29 2e 70 | 69 78 65 6c 53 69 7a 65 |dPMap).p|ixelSize|
|000036a0| 2c 31 2c 31 29 3b 0d 09 | 47 44 47 65 74 47 72 61 |,1,1);..|GDGetGra|
|000036b0| 79 28 64 65 76 69 63 65 | 2c 26 66 6c 61 67 29 3b |y(device|,&flag);|
|000036c0| 09 09 2f 2a 20 66 6c 61 | 67 3d 30 3a 63 6f 6c 6f |../* fla|g=0:colo|
|000036d0| 72 20 6d 6f 64 65 3b 66 | 6c 61 67 3d 31 3a 67 72 |r mode;f|lag=1:gr|
|000036e0| 61 79 20 6d 6f 64 65 20 | 2a 2f 0d 09 69 66 20 28 |ay mode |*/..if (|
|000036f0| 66 6c 61 67 20 21 3d 20 | 30 29 09 7b 0d 09 09 50 |flag != |0).{...P|
|00003700| 72 69 6e 74 66 45 78 69 | 74 28 22 5c 6e 5c 30 30 |rintfExi|t("\n\00|
|00003710| 37 20 53 6f 72 72 79 2e | 20 59 6f 75 20 6e 65 65 |7 Sorry.| You nee|
|00003720| 64 20 74 6f 20 73 65 74 | 20 74 68 65 20 74 65 73 |d to set| the tes|
|00003730| 74 20 73 63 72 65 65 6e | 20 74 6f 20 63 6f 6c 6f |t screen| to colo|
|00003740| 72 20 6d 6f 64 65 2e 5c | 6e 22 0d 09 09 09 22 48 |r mode.\|n"...."H|
|00003750| 69 74 20 27 52 45 54 55 | 52 4e 27 20 74 6f 20 71 |it 'RETU|RN' to q|
|00003760| 75 69 74 20 74 68 65 20 | 70 72 6f 67 72 61 6d 2e |uit the |program.|
|00003770| 20 47 6f 20 74 6f 20 27 | 4d 6f 6e 69 74 6f 72 73 | Go to '|Monitors|
|00003780| 27 20 69 6e 20 74 68 65 | 20 22 0d 09 09 09 22 27 |' in the| "...."'|
|00003790| 43 6f 6e 74 72 6f 6c 20 | 50 61 6e 65 6c 27 20 61 |Control |Panel' a|
|000037a0| 6e 64 20 73 65 74 20 74 | 6f 20 27 43 6f 6c 6f 72 |nd set t|o 'Color|
|000037b0| 73 27 20 61 6e 64 20 27 | 32 35 36 27 2e 5c 6e 22 |s' and '|256'.\n"|
|000037c0| 29 3b 0d 09 7d 0d 09 70 | 72 69 6e 74 66 28 22 61 |);..}..p|rintf("a|
|000037d0| 6e 64 20 63 6f 6c 6f 72 | 20 6d 6f 64 65 5c 6e 22 |nd color| mode\n"|
|000037e0| 29 3b 0d 09 4c 50 2d 3e | 48 7a 3d 47 44 46 72 61 |);..LP->|Hz=GDFra|
|000037f0| 6d 65 52 61 74 65 28 64 | 65 76 69 63 65 29 3b 0d |meRate(d|evice);.|
|00003800| 09 70 72 69 6e 74 66 28 | 22 54 68 65 20 74 65 73 |.printf(|"The tes|
|00003810| 74 20 73 63 72 65 65 6e | 27 73 20 66 72 61 6d 65 |t screen|'s frame|
|00003820| 20 72 61 74 65 20 69 73 | 20 25 2e 32 66 20 48 7a | rate is| %.2f Hz|
|00003830| 5c 6e 22 2c 4c 50 2d 3e | 48 7a 29 3b 0d 09 0d 09 |\n",LP->|Hz);....|
|00003840| 6d 79 43 68 61 72 3d 27 | 4e 27 3b 0d 09 70 72 69 |myChar='|N';..pri|
|00003850| 6e 74 66 28 22 5c 6e 54 | 68 65 72 65 20 61 72 65 |ntf("\nT|here are|
|00003860| 20 74 77 6f 20 6b 69 6e | 64 73 20 6f 66 20 6d 65 | two kin|ds of me|
|00003870| 61 73 75 72 65 6d 65 6e | 74 3a 5c 6e 22 0d 09 22 |asuremen|t:\n".."|
|00003880| 31 2e 20 43 6f 6d 70 75 | 6c 73 6f 72 79 20 63 61 |1. Compu|lsory ca|
|00003890| 6c 69 62 72 61 74 69 6f | 6e 20 6f 66 20 74 68 65 |libratio|n of the|
|000038a0| 20 28 6e 6f 6e 6c 69 6e | 65 61 72 29 20 6d 6f 6e | (nonlin|ear) mon|
|000038b0| 69 74 6f 72 27 73 20 67 | 61 6d 6d 61 20 66 75 6e |itor's g|amma fun|
|000038c0| 63 74 69 6f 6e 2e 5c 6e | 22 0d 09 22 54 68 69 73 |ction.\n|".."This|
|000038d0| 20 77 69 6c 6c 20 62 65 | 20 61 66 66 65 63 74 65 | will be| affecte|
|000038e0| 64 20 62 79 20 79 6f 75 | 72 20 63 68 6f 69 63 65 |d by you|r choice|
|000038f0| 20 6f 66 20 62 61 63 6b | 67 72 6f 75 6e 64 20 6c | of back|ground l|
|00003900| 75 6d 69 6e 61 6e 63 65 | 2e 5c 6e 22 0d 09 22 32 |uminance|.\n".."2|
|00003910| 2e 20 4f 70 74 69 6f 6e | 61 6c 20 63 61 6c 69 62 |. Option|al calib|
|00003920| 72 61 74 69 6f 6e 20 6f | 66 20 74 68 65 20 28 6c |ration o|f the (l|
|00003930| 69 6e 65 61 72 29 20 49 | 53 52 20 56 69 64 65 6f |inear) I|SR Video|
|00003940| 20 41 74 74 65 6e 75 61 | 74 6f 72 20 33 20 63 68 | Attenua|tor 3 ch|
|00003950| 61 6e 6e 65 6c 20 67 61 | 69 6e 73 2e 5c 6e 22 0d |annel ga|ins.\n".|
|00003960| 09 22 54 68 69 73 20 69 | 73 20 69 6e 64 65 70 65 |."This i|s indepe|
|00003970| 6e 64 65 6e 74 20 6f 66 | 20 74 68 65 20 62 61 63 |ndent of| the bac|
|00003980| 6b 67 72 6f 75 6e 64 2e | 20 49 74 20 74 61 6b 65 |kground.| It take|
|00003990| 73 20 61 62 6f 75 74 20 | 31 35 20 6d 69 6e 75 74 |s about |15 minut|
|000039a0| 65 73 2e 5c 6e 5c 6e 22 | 0d 09 22 44 6f 20 79 6f |es.\n\n"|.."Do yo|
|000039b0| 75 20 77 69 73 68 20 74 | 6f 20 73 6b 69 70 20 32 |u wish t|o skip 2|
|000039c0| 2e 2c 20 74 68 65 20 6f | 70 74 69 6f 6e 61 6c 20 |., the o|ptional |
|000039d0| 74 68 72 65 65 2d 63 68 | 61 6e 6e 65 6c 20 63 61 |three-ch|annel ca|
|000039e0| 6c 69 62 72 61 74 69 6f | 6e 3f 20 28 25 63 29 3a |libratio|n? (%c):|
|000039f0| 22 2c 6d 79 43 68 61 72 | 29 3b 0d 09 67 65 74 73 |",myChar|);..gets|
|00003a00| 28 73 74 72 69 6e 67 29 | 3b 0d 09 73 73 63 61 6e |(string)|;..sscan|
|00003a10| 66 28 28 63 68 61 72 2a | 29 73 74 72 69 6e 67 2c |f((char*|)string,|
|00003a20| 22 25 63 22 2c 26 6d 79 | 43 68 61 72 29 3b 0d 09 |"%c",&my|Char);..|
|00003a30| 73 6b 69 70 52 47 42 3d | 28 74 6f 75 70 70 65 72 |skipRGB=|(toupper|
|00003a40| 28 6d 79 43 68 61 72 29 | 3d 3d 27 59 27 29 3b 0d |(myChar)|=='Y');.|
|00003a50| 09 69 66 28 73 6b 69 70 | 52 47 42 29 20 70 72 69 |.if(skip|RGB) pri|
|00003a60| 6e 74 66 28 22 53 6b 69 | 70 70 69 6e 67 20 33 20 |ntf("Ski|pping 3 |
|00003a70| 63 68 61 6e 6e 65 6c 20 | 63 61 6c 69 62 72 61 74 |channel |calibrat|
|00003a80| 69 6f 6e 2e 5c 6e 22 29 | 3b 0d 09 65 6c 73 65 20 |ion.\n")|;..else |
|00003a90| 70 72 69 6e 74 66 28 22 | 33 20 63 68 61 6e 6e 65 |printf("|3 channe|
|00003aa0| 6c 73 20 77 69 6c 6c 20 | 62 65 20 63 61 6c 69 62 |ls will |be calib|
|00003ab0| 72 61 74 65 64 2e 5c 6e | 22 29 3b 0d 09 0d 09 66 |rated.\n|");....f|
|00003ac0| 72 61 6d 65 73 3d 30 3b | 0d 09 69 66 28 61 75 74 |rames=0;|..if(aut|
|00003ad0| 6f 6d 61 74 69 63 29 7b | 0d 09 09 66 72 61 6d 65 |omatic){|...frame|
|00003ae0| 73 3d 4e 46 52 41 4d 45 | 3b 0d 09 09 70 72 69 6e |s=NFRAME|;...prin|
|00003af0| 74 66 28 22 54 61 6b 69 | 6e 67 20 70 68 6f 74 6f |tf("Taki|ng photo|
|00003b00| 6d 65 74 65 72 20 72 65 | 61 64 69 6e 67 73 20 61 |meter re|adings a|
|00003b10| 75 74 6f 6d 61 74 69 63 | 61 6c 6c 79 2e 5c 6e 22 |utomatic|ally.\n"|
|00003b20| 0d 09 09 09 22 41 73 73 | 75 6d 69 6e 67 20 25 2e |...."Ass|uming %.|
|00003b30| 33 66 20 6d 69 6c 6c 69 | 56 6f 6c 74 73 20 70 65 |3f milli|Volts pe|
|00003b40| 72 20 25 73 5c 6e 22 2c | 31 30 30 30 2e 30 2f 4c |r %s\n",|1000.0/L|
|00003b50| 75 6d 69 6e 61 6e 63 65 | 50 65 72 56 6f 6c 74 61 |uminance|PerVolta|
|00003b60| 67 65 2c 4c 50 2d 3e 75 | 6e 69 74 73 29 3b 0d 09 |ge,LP->u|nits);..|
|00003b70| 7d 0d 09 65 6c 73 65 20 | 70 72 69 6e 74 66 28 22 |}..else |printf("|
|00003b80| 50 6c 65 61 73 65 20 65 | 6e 74 65 72 20 74 68 65 |Please e|nter the|
|00003b90| 20 70 68 6f 74 6f 6d 65 | 74 65 72 20 72 65 61 64 | photome|ter read|
|00003ba0| 69 6e 67 73 2c 69 6e 20 | 25 73 2c 20 61 73 20 70 |ings,in |%s, as p|
|00003bb0| 72 6f 6d 70 74 65 64 2e | 5c 6e 22 2c 4c 50 2d 3e |rompted.|\n",LP->|
|00003bc0| 75 6e 69 74 73 29 3b 20 | 0d 09 70 72 69 6e 74 66 |units); |..printf|
|00003bd0| 28 22 5c 6e 22 29 3b 0d | 0d 09 70 72 69 6e 74 66 |("\n");.|..printf|
|00003be0| 28 22 46 69 72 73 74 20 | 6c 65 74 27 73 20 63 68 |("First |let's ch|
|00003bf0| 65 63 6b 20 74 68 65 20 | 70 68 6f 74 6f 6d 65 74 |eck the |photomet|
|00003c00| 65 72 27 73 20 67 61 69 | 6e 20 73 65 74 74 69 6e |er's gai|n settin|
|00003c10| 67 2e 5c 6e 22 29 3b 0d | 09 70 72 69 6e 74 66 28 |g.\n");.|.printf(|
|00003c20| 22 50 6f 69 6e 74 20 74 | 68 65 20 70 68 6f 74 6f |"Point t|he photo|
|00003c30| 6d 65 74 65 72 20 61 74 | 20 74 68 65 20 73 63 72 |meter at| the scr|
|00003c40| 65 65 6e 20 61 6e 64 20 | 68 69 74 20 72 65 74 75 |een and |hit retu|
|00003c50| 72 6e 3a 22 29 3b 0d 09 | 67 65 74 73 28 73 74 72 |rn:");..|gets(str|
|00003c60| 69 6e 67 29 3b 0d 09 64 | 6f 7b 0d 09 09 53 65 74 |ing);..d|o{...Set|
|00003c70| 50 6f 72 74 28 77 69 6e | 64 6f 77 29 3b 0d 09 09 |Port(win|dow);...|
|00003c80| 42 72 69 6e 67 54 6f 46 | 72 6f 6e 74 28 77 69 6e |BringToF|ront(win|
|00003c90| 64 6f 77 29 3b 0d 09 09 | 46 69 6c 6c 52 65 63 74 |dow);...|FillRect|
|00003ca0| 28 26 77 69 6e 64 6f 77 | 2d 3e 70 6f 72 74 52 65 |(&window|->portRe|
|00003cb0| 63 74 2c 71 64 2e 62 6c | 61 63 6b 29 3b 0d 09 09 |ct,qd.bl|ack);...|
|00003cc0| 64 61 72 6b 4c 75 6d 69 | 6e 61 6e 63 65 3d 47 65 |darkLumi|nance=Ge|
|00003cd0| 74 41 4c 75 6d 69 6e 61 | 6e 63 65 28 4c 50 2c 64 |tALumina|nce(LP,d|
|00003ce0| 65 76 69 63 65 2c 66 72 | 61 6d 65 73 2c 4c 75 6d |evice,fr|ames,Lum|
|00003cf0| 69 6e 61 6e 63 65 50 65 | 72 56 6f 6c 74 61 67 65 |inancePe|rVoltage|
|00003d00| 2c 30 2c 4c 50 2d 3e 56 | 4d 61 78 2c 4c 50 2d 3e |,0,LP->V|Max,LP->|
|00003d10| 56 4d 61 78 2c 4c 50 2d | 3e 56 4d 61 78 29 3b 0d |VMax,LP-|>VMax);.|
|00003d20| 09 09 46 69 6c 6c 52 65 | 63 74 28 26 77 69 6e 64 |..FillRe|ct(&wind|
|00003d30| 6f 77 2d 3e 70 6f 72 74 | 52 65 63 74 2c 71 64 2e |ow->port|Rect,qd.|
|00003d40| 77 68 69 74 65 29 3b 0d | 09 09 6c 75 6d 69 6e 61 |white);.|..lumina|
|00003d50| 6e 63 65 3d 47 65 74 41 | 4c 75 6d 69 6e 61 6e 63 |nce=GetA|Luminanc|
|00003d60| 65 28 4c 50 2c 64 65 76 | 69 63 65 2c 66 72 61 6d |e(LP,dev|ice,fram|
|00003d70| 65 73 2c 4c 75 6d 69 6e | 61 6e 63 65 50 65 72 56 |es,Lumin|ancePerV|
|00003d80| 6f 6c 74 61 67 65 2c 30 | 2c 4c 50 2d 3e 56 4d 61 |oltage,0|,LP->VMa|
|00003d90| 78 2c 4c 50 2d 3e 56 4d | 61 78 2c 4c 50 2d 3e 56 |x,LP->VM|ax,LP->V|
|00003da0| 4d 61 78 29 3b 0d 09 09 | 6c 75 6d 69 6e 61 6e 63 |Max);...|luminanc|
|00003db0| 65 2d 3d 64 61 72 6b 4c | 75 6d 69 6e 61 6e 63 65 |e-=darkL|uminance|
|00003dc0| 3b 0d 09 09 53 65 6e 64 | 42 65 68 69 6e 64 28 77 |;...Send|Behind(w|
|00003dd0| 69 6e 64 6f 77 2c 4e 55 | 4c 4c 29 3b 0d 09 09 70 |indow,NU|LL);...p|
|00003de0| 72 69 6e 74 66 28 22 57 | 68 69 74 65 20 73 65 65 |rintf("W|hite see|
|00003df0| 6d 73 20 74 6f 20 62 65 | 20 25 2e 31 66 20 25 73 |ms to be| %.1f %s|
|00003e00| 20 62 72 69 67 68 74 65 | 72 20 74 68 61 6e 20 62 | brighte|r than b|
|00003e10| 6c 61 63 6b 2e 5c 6e 22 | 2c 6c 75 6d 69 6e 61 6e |lack.\n"|,luminan|
|00003e20| 63 65 2c 4c 50 2d 3e 75 | 6e 69 74 73 29 3b 0d 09 |ce,LP->u|nits);..|
|00003e30| 09 6d 79 43 68 61 72 3d | 27 4e 27 3b 0d 09 09 70 |.myChar=|'N';...p|
|00003e40| 72 69 6e 74 66 28 22 44 | 6f 20 79 6f 75 20 77 61 |rintf("D|o you wa|
|00003e50| 6e 74 20 74 6f 20 74 72 | 79 20 74 68 61 74 20 61 |nt to tr|y that a|
|00003e60| 67 61 69 6e 3f 20 28 25 | 63 29 3a 22 2c 6d 79 43 |gain? (%|c):",myC|
|00003e70| 68 61 72 29 3b 0d 09 09 | 67 65 74 73 28 73 74 72 |har);...|gets(str|
|00003e80| 69 6e 67 29 3b 0d 09 09 | 73 73 63 61 6e 66 28 28 |ing);...|sscanf((|
|00003e90| 63 68 61 72 2a 29 73 74 | 72 69 6e 67 2c 22 25 63 |char*)st|ring,"%c|
|00003ea0| 22 2c 26 6d 79 43 68 61 | 72 29 3b 0d 09 7d 77 68 |",&myCha|r);..}wh|
|00003eb0| 69 6c 65 28 74 6f 75 70 | 70 65 72 28 6d 79 43 68 |ile(toup|per(myCh|
|00003ec0| 61 72 29 3d 3d 27 59 27 | 29 3b 0d 0d 09 70 72 69 |ar)=='Y'|);...pri|
|00003ed0| 6e 74 66 28 22 50 6c 65 | 61 73 65 20 6f 63 63 6c |ntf("Ple|ase occl|
|00003ee0| 75 64 65 20 74 68 65 20 | 70 68 6f 74 6f 6d 65 74 |ude the |photomet|
|00003ef0| 65 72 20 73 6f 20 74 68 | 61 74 20 49 20 63 61 6e |er so th|at I can|
|00003f00| 20 72 65 61 64 20 74 68 | 65 20 64 61 72 6b 20 6c | read th|e dark l|
|00003f10| 65 76 65 6c 2e 5c 6e 22 | 0d 09 22 48 69 74 20 63 |evel.\n"|.."Hit c|
|00003f20| 72 20 77 68 65 6e 20 72 | 65 61 64 79 3a 22 29 3b |r when r|eady:");|
|00003f30| 0d 09 67 65 74 73 28 73 | 74 72 69 6e 67 29 3b 0d |..gets(s|tring);.|
|00003f40| 09 64 61 72 6b 4c 75 6d | 69 6e 61 6e 63 65 3d 47 |.darkLum|inance=G|
|00003f50| 65 74 41 4c 75 6d 69 6e | 61 6e 63 65 28 4c 50 2c |etALumin|ance(LP,|
|00003f60| 64 65 76 69 63 65 2c 66 | 72 61 6d 65 73 2c 4c 75 |device,f|rames,Lu|
|00003f70| 6d 69 6e 61 6e 63 65 50 | 65 72 56 6f 6c 74 61 67 |minanceP|erVoltag|
|00003f80| 65 2c 30 2c 4c 50 2d 3e | 56 4d 61 78 2c 4c 50 2d |e,0,LP->|VMax,LP-|
|00003f90| 3e 56 4d 61 78 2c 4c 50 | 2d 3e 56 4d 61 78 29 3b |>VMax,LP|->VMax);|
|00003fa0| 0d 09 70 72 69 6e 74 66 | 28 22 54 68 65 20 64 61 |..printf|("The da|
|00003fb0| 72 6b 20 6c 65 76 65 6c | 20 6f 66 20 25 2e 32 66 |rk level| of %.2f|
|00003fc0| 20 63 64 2f 6d 5e 32 20 | 77 69 6c 6c 20 62 65 20 | cd/m^2 |will be |
|00003fd0| 73 75 62 74 72 61 63 74 | 65 64 20 66 72 6f 6d 20 |subtract|ed from |
|00003fe0| 61 6c 6c 20 72 65 61 64 | 69 6e 67 73 5c 6e 22 0d |all read|ings\n".|
|00003ff0| 09 09 2c 64 61 72 6b 4c | 75 6d 69 6e 61 6e 63 65 |..,darkL|uminance|
|00004000| 29 3b 0d 09 0d 09 74 65 | 73 74 53 69 7a 65 3d 31 |);....te|stSize=1|
|00004010| 36 30 3b 0d 09 70 72 69 | 6e 74 66 28 22 45 6e 74 |60;..pri|ntf("Ent|
|00004020| 65 72 2c 20 69 6e 20 70 | 69 78 65 6c 73 2c 20 74 |er, in p|ixels, t|
|00004030| 68 65 20 64 69 61 6d 65 | 74 65 72 20 6f 66 20 74 |he diame|ter of t|
|00004040| 68 65 20 74 65 73 74 20 | 70 61 74 63 68 20 28 25 |he test |patch (%|
|00004050| 64 29 3a 22 2c 74 65 73 | 74 53 69 7a 65 29 3b 0d |d):",tes|tSize);.|
|00004060| 09 67 65 74 73 28 73 74 | 72 69 6e 67 29 3b 0d 09 |.gets(st|ring);..|
|00004070| 73 73 63 61 6e 66 28 28 | 63 68 61 72 20 2a 29 73 |sscanf((|char *)s|
|00004080| 74 72 69 6e 67 2c 22 25 | 64 22 2c 26 74 65 73 74 |tring,"%|d",&test|
|00004090| 53 69 7a 65 29 3b 0d 0d | 09 2f 2a 20 64 72 61 77 |Size);..|./* draw|
|000040a0| 20 63 69 72 63 6c 65 20 | 66 6f 72 20 70 6c 61 63 | circle |for plac|
|000040b0| 65 6d 65 6e 74 20 6f 66 | 20 70 68 6f 74 6f 63 65 |ement of| photoce|
|000040c0| 6c 6c 20 2a 2f 0d 09 53 | 65 74 50 6f 72 74 28 77 |ll */..S|etPort(w|
|000040d0| 69 6e 64 6f 77 29 3b 0d | 09 6d 79 52 65 63 74 20 |indow);.|.myRect |
|000040e0| 3d 20 77 69 6e 64 6f 77 | 2d 3e 70 6f 72 74 52 65 |= window|->portRe|
|000040f0| 63 74 3b 0d 09 49 6e 73 | 65 74 52 65 63 74 28 26 |ct;..Ins|etRect(&|
|00004100| 6d 79 52 65 63 74 2c 28 | 6d 79 52 65 63 74 2e 72 |myRect,(|myRect.r|
|00004110| 69 67 68 74 2d 74 65 73 | 74 53 69 7a 65 29 2f 32 |ight-tes|tSize)/2|
|00004120| 2c 28 6d 79 52 65 63 74 | 2e 62 6f 74 74 6f 6d 2d |,(myRect|.bottom-|
|00004130| 74 65 73 74 53 69 7a 65 | 29 2f 32 29 3b 0d 09 50 |testSize|)/2);..P|
|00004140| 6d 46 6f 72 65 43 6f 6c | 6f 72 28 32 35 35 29 3b |mForeCol|or(255);|
|00004150| 0d 09 50 65 6e 53 69 7a | 65 28 31 30 2c 31 30 29 |..PenSiz|e(10,10)|
|00004160| 3b 0d 09 46 72 61 6d 65 | 4f 76 61 6c 28 26 6d 79 |;..Frame|Oval(&my|
|00004170| 52 65 63 74 29 3b 0d 09 | 53 65 74 50 6f 72 74 28 |Rect);..|SetPort(|
|00004180| 6f 6c 64 57 69 6e 64 6f | 77 29 3b 0d 09 0d 09 70 |oldWindo|w);....p|
|00004190| 72 69 6e 74 66 28 22 50 | 6c 65 61 73 65 20 72 65 |rintf("P|lease re|
|000041a0| 6d 6f 76 65 20 74 68 65 | 20 6f 63 63 6c 75 64 65 |move the| occlude|
|000041b0| 72 2e 20 5c 6e 22 29 3b | 0d 09 70 72 69 6e 74 66 |r. \n");|..printf|
|000041c0| 28 22 50 6c 61 63 65 20 | 79 6f 75 72 20 70 68 6f |("Place |your pho|
|000041d0| 74 6f 6d 65 74 65 72 20 | 73 6f 20 61 73 20 74 6f |tometer |so as to|
|000041e0| 20 72 65 61 64 20 74 68 | 65 20 6c 75 6d 69 6e 61 | read th|e lumina|
|000041f0| 6e 63 65 20 6f 66 20 74 | 68 65 20 22 0d 09 09 22 |nce of t|he "..."|
|00004200| 63 65 6e 74 65 72 20 6f | 66 20 74 68 65 20 74 65 |center o|f the te|
|00004210| 73 74 20 73 63 72 65 65 | 6e 2e 5c 6e 22 29 3b 20 |st scree|n.\n"); |
|00004220| 0d 0d 09 69 66 28 73 6b | 69 70 52 47 42 29 63 79 |...if(sk|ipRGB)cy|
|00004230| 63 6c 65 73 3d 31 3b 0d | 09 65 6c 73 65 20 63 79 |cles=1;.|.else cy|
|00004240| 63 6c 65 73 3d 34 3b 0d | 09 70 72 69 6e 74 66 28 |cles=4;.|.printf(|
|00004250| 22 54 68 65 6e 20 65 6e | 74 65 72 20 6e 75 6d 62 |"Then en|ter numb|
|00004260| 65 72 20 6f 66 20 74 69 | 6d 65 73 20 79 6f 75 20 |er of ti|mes you |
|00004270| 77 69 73 68 20 74 6f 20 | 72 65 70 65 61 74 20 74 |wish to |repeat t|
|00004280| 68 65 20 77 68 6f 6c 65 | 20 63 79 63 6c 65 20 6f |he whole| cycle o|
|00004290| 66 20 6d 65 61 73 75 72 | 65 6d 65 6e 74 2e 20 28 |f measur|ement. (|
|000042a0| 25 64 29 3a 22 0d 09 09 | 2c 63 79 63 6c 65 73 29 |%d):"...|,cycles)|
|000042b0| 3b 0d 09 67 65 74 73 28 | 28 63 68 61 72 20 2a 29 |;..gets(|(char *)|
|000042c0| 73 74 72 69 6e 67 29 3b | 0d 09 73 73 63 61 6e 66 |string);|..sscanf|
|000042d0| 28 28 63 68 61 72 20 2a | 29 73 74 72 69 6e 67 2c |((char *|)string,|
|000042e0| 22 25 64 22 2c 26 63 79 | 63 6c 65 73 29 3b 0d 09 |"%d",&cy|cles);..|
|000042f0| 69 66 28 63 79 63 6c 65 | 73 3c 3d 30 29 72 65 74 |if(cycle|s<=0)ret|
|00004300| 75 72 6e 3b 0d 0d 09 53 | 65 74 50 6f 72 74 28 77 |urn;...S|etPort(w|
|00004310| 69 6e 64 6f 77 29 3b 0d | 09 42 72 69 6e 67 54 6f |indow);.|.BringTo|
|00004320| 46 72 6f 6e 74 28 77 69 | 6e 64 6f 77 29 3b 0d 09 |Front(wi|ndow);..|
|00004330| 46 69 6c 6c 52 65 63 74 | 28 26 77 69 6e 64 6f 77 |FillRect|(&window|
|00004340| 2d 3e 70 6f 72 74 52 65 | 63 74 2c 71 64 2e 67 72 |->portRe|ct,qd.gr|
|00004350| 61 79 29 3b 0d 09 6c 75 | 6d 69 6e 61 6e 63 65 3d |ay);..lu|minance=|
|00004360| 47 65 74 41 4c 75 6d 69 | 6e 61 6e 63 65 28 4c 50 |GetALumi|nance(LP|
|00004370| 2c 64 65 76 69 63 65 2c | 66 72 61 6d 65 73 2c 4c |,device,|frames,L|
|00004380| 75 6d 69 6e 61 6e 63 65 | 50 65 72 56 6f 6c 74 61 |uminance|PerVolta|
|00004390| 67 65 2c 30 2c 4c 50 2d | 3e 56 4d 61 78 2c 4c 50 |ge,0,LP-|>VMax,LP|
|000043a0| 2d 3e 56 4d 61 78 2c 4c | 50 2d 3e 56 4d 61 78 29 |->VMax,L|P->VMax)|
|000043b0| 3b 0d 09 6c 75 6d 69 6e | 61 6e 63 65 2d 3d 64 61 |;..lumin|ance-=da|
|000043c0| 72 6b 4c 75 6d 69 6e 61 | 6e 63 65 3b 0d 09 70 72 |rkLumina|nce;..pr|
|000043d0| 69 6e 74 66 28 22 35 30 | 25 25 20 64 69 74 68 65 |intf("50|%% dithe|
|000043e0| 72 65 64 20 67 72 61 79 | 20 69 73 20 25 2e 31 66 |red gray| is %.1f|
|000043f0| 20 25 73 5c 6e 22 2c 6c | 75 6d 69 6e 61 6e 63 65 | %s\n",l|uminance|
|00004400| 2c 4c 50 2d 3e 75 6e 69 | 74 73 29 3b 0d 09 46 69 |,LP->uni|ts);..Fi|
|00004410| 6c 6c 52 65 63 74 28 26 | 77 69 6e 64 6f 77 2d 3e |llRect(&|window->|
|00004420| 70 6f 72 74 52 65 63 74 | 2c 71 64 2e 77 68 69 74 |portRect|,qd.whit|
|00004430| 65 29 3b 0d 09 6c 75 6d | 69 6e 61 6e 63 65 3d 47 |e);..lum|inance=G|
|00004440| 65 74 41 4c 75 6d 69 6e | 61 6e 63 65 28 4c 50 2c |etALumin|ance(LP,|
|00004450| 64 65 76 69 63 65 2c 66 | 72 61 6d 65 73 2c 4c 75 |device,f|rames,Lu|
|00004460| 6d 69 6e 61 6e 63 65 50 | 65 72 56 6f 6c 74 61 67 |minanceP|erVoltag|
|00004470| 65 2c 30 2c 4c 50 2d 3e | 56 4d 61 78 2c 4c 50 2d |e,0,LP->|VMax,LP-|
|00004480| 3e 56 4d 61 78 2c 4c 50 | 2d 3e 56 4d 61 78 29 3b |>VMax,LP|->VMax);|
|00004490| 0d 09 6c 75 6d 69 6e 61 | 6e 63 65 2d 3d 64 61 72 |..lumina|nce-=dar|
|000044a0| 6b 4c 75 6d 69 6e 61 6e | 63 65 3b 0d 09 70 72 69 |kLuminan|ce;..pri|
|000044b0| 6e 74 66 28 22 57 68 69 | 74 65 20 69 73 20 25 2e |ntf("Whi|te is %.|
|000044c0| 31 66 20 25 73 5c 6e 22 | 2c 6c 75 6d 69 6e 61 6e |1f %s\n"|,luminan|
|000044d0| 63 65 2c 4c 50 2d 3e 75 | 6e 69 74 73 29 3b 0d 09 |ce,LP->u|nits);..|
|000044e0| 46 69 6c 6c 52 65 63 74 | 28 26 77 69 6e 64 6f 77 |FillRect|(&window|
|000044f0| 2d 3e 70 6f 72 74 52 65 | 63 74 2c 71 64 2e 62 6c |->portRe|ct,qd.bl|
|00004500| 61 63 6b 29 3b 0d 09 6c | 75 6d 69 6e 61 6e 63 65 |ack);..l|uminance|
|00004510| 3d 47 65 74 41 4c 75 6d | 69 6e 61 6e 63 65 28 4c |=GetALum|inance(L|
|00004520| 50 2c 64 65 76 69 63 65 | 2c 66 72 61 6d 65 73 2c |P,device|,frames,|
|00004530| 4c 75 6d 69 6e 61 6e 63 | 65 50 65 72 56 6f 6c 74 |Luminanc|ePerVolt|
|00004540| 61 67 65 2c 30 2c 4c 50 | 2d 3e 56 4d 61 78 2c 4c |age,0,LP|->VMax,L|
|00004550| 50 2d 3e 56 4d 61 78 2c | 4c 50 2d 3e 56 4d 61 78 |P->VMax,|LP->VMax|
|00004560| 29 3b 0d 09 6c 75 6d 69 | 6e 61 6e 63 65 2d 3d 64 |);..lumi|nance-=d|
|00004570| 61 72 6b 4c 75 6d 69 6e | 61 6e 63 65 3b 0d 09 70 |arkLumin|ance;..p|
|00004580| 72 69 6e 74 66 28 22 42 | 6c 61 63 6b 20 69 73 20 |rintf("B|lack is |
|00004590| 25 2e 31 66 20 25 73 5c | 6e 22 2c 6c 75 6d 69 6e |%.1f %s\|n",lumin|
|000045a0| 61 6e 63 65 2c 4c 50 2d | 3e 75 6e 69 74 73 29 3b |ance,LP-|>units);|
|000045b0| 0d 09 53 65 6e 64 42 65 | 68 69 6e 64 28 77 69 6e |..SendBe|hind(win|
|000045c0| 64 6f 77 2c 4e 55 4c 4c | 29 3b 0d 0d 09 70 72 69 |dow,NULL|);...pri|
|000045d0| 6e 74 66 28 22 49 74 20 | 69 73 20 65 73 73 65 6e |ntf("It |is essen|
|000045e0| 74 69 61 6c 20 74 68 61 | 74 20 74 68 65 20 63 61 |tial tha|t the ca|
|000045f0| 6c 69 62 72 61 74 69 6f | 6e 20 62 65 20 6d 61 64 |libratio|n be mad|
|00004600| 65 20 77 69 74 68 20 74 | 68 65 20 73 61 6d 65 20 |e with t|he same |
|00004610| 62 61 63 6b 67 72 6f 75 | 6e 64 5c 6e 22 0d 09 22 |backgrou|nd\n".."|
|00004620| 6c 75 6d 69 6e 61 6e 63 | 65 20 61 73 20 77 69 6c |luminanc|e as wil|
|00004630| 6c 20 75 6c 74 69 6d 61 | 74 65 6c 79 20 62 65 20 |l ultima|tely be |
|00004640| 75 73 65 64 20 69 6e 20 | 79 6f 75 72 20 65 78 70 |used in |your exp|
|00004650| 65 72 69 6d 65 6e 74 73 | 2e 20 59 6f 75 20 6d 61 |eriments|. You ma|
|00004660| 79 20 73 70 65 63 69 66 | 79 20 74 68 65 5c 6e 22 |y specif|y the\n"|
|00004670| 0d 09 22 62 61 63 6b 67 | 72 6f 75 6e 64 20 6c 75 |.."backg|round lu|
|00004680| 6d 69 6e 61 6e 63 65 20 | 65 69 74 68 65 72 20 61 |minance |either a|
|00004690| 73 20 61 20 6c 75 6d 69 | 6e 61 6e 63 65 20 69 6e |s a lumi|nance in|
|000046a0| 20 25 73 2c 20 6f 72 20 | 61 73 20 61 20 63 6f 72 | %s, or |as a cor|
|000046b0| 72 65 73 70 6f 6e 64 69 | 6e 67 20 5c 6e 22 0d 09 |respondi|ng \n"..|
|000046c0| 22 44 41 43 20 76 61 6c | 75 65 20 28 30 2e 2e 25 |"DAC val|ue (0..%|
|000046d0| 64 29 2e 5c 6e 22 2c 4c | 50 2d 3e 75 6e 69 74 73 |d).\n",L|P->units|
|000046e0| 2c 4c 50 2d 3e 56 4d 61 | 78 29 3b 0d 09 6d 79 43 |,LP->VMa|x);..myC|
|000046f0| 68 61 72 3d 27 59 27 3b | 0d 09 70 72 69 6e 74 66 |har='Y';|..printf|
|00004700| 28 22 44 6f 20 79 6f 75 | 20 77 69 73 68 20 74 6f |("Do you| wish to|
|00004710| 20 65 6e 74 65 72 20 61 | 20 6c 75 6d 69 6e 61 6e | enter a| luminan|
|00004720| 63 65 3f 20 28 25 63 29 | 3a 22 2c 6d 79 43 68 61 |ce? (%c)|:",myCha|
|00004730| 72 29 3b 0d 09 67 65 74 | 73 28 73 74 72 69 6e 67 |r);..get|s(string|
|00004740| 29 3b 0d 09 73 73 63 61 | 6e 66 28 28 63 68 61 72 |);..ssca|nf((char|
|00004750| 20 2a 29 73 74 72 69 6e | 67 2c 22 25 63 22 2c 26 | *)strin|g,"%c",&|
|00004760| 6d 79 43 68 61 72 29 3b | 0d 09 69 66 28 74 6f 75 |myChar);|..if(tou|
|00004770| 70 70 65 72 28 6d 79 43 | 68 61 72 29 3d 3d 27 59 |pper(myC|har)=='Y|
|00004780| 27 29 7b 0d 09 09 70 72 | 69 6e 74 66 28 22 45 6e |'){...pr|intf("En|
|00004790| 74 65 72 20 74 68 65 20 | 64 65 73 69 72 65 64 20 |ter the |desired |
|000047a0| 62 61 63 6b 67 72 6f 75 | 6e 64 20 6c 75 6d 69 6e |backgrou|nd lumin|
|000047b0| 61 6e 63 65 20 69 6e 20 | 25 73 20 28 25 66 29 3a |ance in |%s (%f):|
|000047c0| 22 2c 4c 50 2d 3e 75 6e | 69 74 73 2c 4c 50 2d 3e |",LP->un|its,LP->|
|000047d0| 4c 42 61 63 6b 67 72 6f | 75 6e 64 29 3b 0d 09 09 |LBackgro|und);...|
|000047e0| 67 65 74 73 28 73 74 72 | 69 6e 67 29 3b 0d 09 09 |gets(str|ing);...|
|000047f0| 73 73 63 61 6e 66 28 73 | 74 72 69 6e 67 2c 22 25 |sscanf(s|tring,"%|
|00004800| 6c 66 22 2c 26 4c 50 2d | 3e 4c 42 61 63 6b 67 72 |lf",&LP-|>LBackgr|
|00004810| 6f 75 6e 64 29 3b 0d 09 | 09 70 72 69 6e 74 66 28 |ound);..|.printf(|
|00004820| 22 4e 6f 77 20 68 75 6e | 74 69 6e 67 20 66 6f 72 |"Now hun|ting for|
|00004830| 20 74 68 65 20 44 41 43 | 20 76 61 6c 75 65 20 2e | the DAC| value .|
|00004840| 20 2e 20 2e 5c 6e 22 29 | 3b 0d 09 09 4c 54 6f 56 | . .\n")|;...LToV|
|00004850| 48 75 6e 74 28 4c 50 2c | 64 65 76 69 63 65 2c 28 |Hunt(LP,|device,(|
|00004860| 43 57 69 6e 64 6f 77 50 | 74 72 29 77 69 6e 64 6f |CWindowP|tr)windo|
|00004870| 77 2c 4c 75 6d 69 6e 61 | 6e 63 65 50 65 72 56 6f |w,Lumina|ncePerVo|
|00004880| 6c 74 61 67 65 2c 66 72 | 61 6d 65 73 2c 64 61 72 |ltage,fr|ames,dar|
|00004890| 6b 4c 75 6d 69 6e 61 6e | 63 65 29 3b 0d 09 09 70 |kLuminan|ce);...p|
|000048a0| 72 69 6e 74 66 28 22 57 | 69 6c 6c 20 75 73 65 20 |rintf("W|ill use |
|000048b0| 74 68 65 20 6e 65 61 72 | 65 73 74 20 44 41 43 20 |the near|est DAC |
|000048c0| 76 61 6c 75 65 2c 20 77 | 68 69 63 68 20 69 73 20 |value, w|hich is |
|000048d0| 25 64 5c 6e 22 2c 4c 50 | 2d 3e 56 42 61 63 6b 67 |%d\n",LP|->VBackg|
|000048e0| 72 6f 75 6e 64 29 3b 0d | 09 7d 0d 09 65 6c 73 65 |round);.|.}..else|
|000048f0| 20 7b 0d 09 09 70 72 69 | 6e 74 66 28 22 45 6e 74 | {...pri|ntf("Ent|
|00004900| 65 72 20 74 68 65 20 44 | 41 43 20 76 61 6c 75 65 |er the D|AC value|
|00004910| 20 66 6f 72 20 74 68 65 | 20 62 61 63 6b 67 72 6f | for the| backgro|
|00004920| 75 6e 64 20 28 25 64 29 | 3a 22 2c 4c 50 2d 3e 56 |und (%d)|:",LP->V|
|00004930| 42 61 63 6b 67 72 6f 75 | 6e 64 29 3b 0d 09 09 67 |Backgrou|nd);...g|
|00004940| 65 74 73 28 73 74 72 69 | 6e 67 29 3b 0d 09 09 73 |ets(stri|ng);...s|
|00004950| 73 63 61 6e 66 28 28 63 | 68 61 72 20 2a 29 73 74 |scanf((c|har *)st|
|00004960| 72 69 6e 67 2c 22 25 64 | 22 2c 26 4c 50 2d 3e 56 |ring,"%d|",&LP->V|
|00004970| 42 61 63 6b 67 72 6f 75 | 6e 64 29 3b 0d 09 7d 0d |Backgrou|nd);..}.|
|00004980| 09 4c 50 2d 3e 74 61 62 | 6c 65 5b 32 5d 2e 72 67 |.LP->tab|le[2].rg|
|00004990| 62 2e 72 65 64 20 3d 20 | 4c 50 2d 3e 74 61 62 6c |b.red = |LP->tabl|
|000049a0| 65 5b 32 5d 2e 72 67 62 | 2e 67 72 65 65 6e 20 3d |e[2].rgb|.green =|
|000049b0| 20 20 4c 50 2d 3e 74 61 | 62 6c 65 5b 32 5d 2e 72 | LP->ta|ble[2].r|
|000049c0| 67 62 2e 62 6c 75 65 20 | 3d 20 0d 09 09 4c 50 2d |gb.blue |= ...LP-|
|000049d0| 3e 56 42 61 63 6b 67 72 | 6f 75 6e 64 3c 3c 4c 50 |>VBackgr|ound<<LP|
|000049e0| 2d 3e 6c 65 66 74 53 68 | 69 66 74 3b 0d 09 4c 6f |->leftSh|ift;..Lo|
|000049f0| 61 64 4c 75 6d 69 6e 61 | 6e 63 65 73 28 64 65 76 |adLumina|nces(dev|
|00004a00| 69 63 65 2c 4c 50 2c 32 | 2c 32 29 3b 0d 09 53 65 |ice,LP,2|,2);..Se|
|00004a10| 74 50 6f 72 74 28 77 69 | 6e 64 6f 77 29 3b 0d 09 |tPort(wi|ndow);..|
|00004a20| 42 72 69 6e 67 54 6f 46 | 72 6f 6e 74 28 77 69 6e |BringToF|ront(win|
|00004a30| 64 6f 77 29 3b 0d 09 50 | 6d 42 61 63 6b 43 6f 6c |dow);..P|mBackCol|
|00004a40| 6f 72 28 32 29 3b 0d 09 | 45 72 61 73 65 52 65 63 |or(2);..|EraseRec|
|00004a50| 74 28 26 77 69 6e 64 6f | 77 2d 3e 70 6f 72 74 52 |t(&windo|w->portR|
|00004a60| 65 63 74 29 3b 0d 09 6c | 75 6d 69 6e 61 6e 63 65 |ect);..l|uminance|
|00004a70| 3d 47 65 74 41 4c 75 6d | 69 6e 61 6e 63 65 28 4c |=GetALum|inance(L|
|00004a80| 50 2c 64 65 76 69 63 65 | 2c 66 72 61 6d 65 73 2c |P,device|,frames,|
|00004a90| 4c 75 6d 69 6e 61 6e 63 | 65 50 65 72 56 6f 6c 74 |Luminanc|ePerVolt|
|00004aa0| 61 67 65 2c 30 2c 4c 50 | 2d 3e 56 4d 61 78 2c 4c |age,0,LP|->VMax,L|
|00004ab0| 50 2d 3e 56 4d 61 78 2c | 4c 50 2d 3e 56 4d 61 78 |P->VMax,|LP->VMax|
|00004ac0| 29 3b 0d 09 6c 75 6d 69 | 6e 61 6e 63 65 2d 3d 64 |);..lumi|nance-=d|
|00004ad0| 61 72 6b 4c 75 6d 69 6e | 61 6e 63 65 3b 0d 09 53 |arkLumin|ance;..S|
|00004ae0| 65 6e 64 42 65 68 69 6e | 64 28 77 69 6e 64 6f 77 |endBehin|d(window|
|00004af0| 2c 4e 55 4c 4c 29 3b 0d | 09 53 65 74 50 6f 72 74 |,NULL);.|.SetPort|
|00004b00| 28 6f 6c 64 57 69 6e 64 | 6f 77 29 3b 0d 09 70 72 |(oldWind|ow);..pr|
|00004b10| 69 6e 74 66 28 22 59 6f | 75 72 20 62 61 63 6b 67 |intf("Yo|ur backg|
|00004b20| 72 6f 75 6e 64 20 6c 75 | 6d 69 6e 61 6e 63 65 20 |round lu|minance |
|00004b30| 69 73 20 25 2e 33 66 20 | 25 73 5c 6e 22 2c 6c 75 |is %.3f |%s\n",lu|
|00004b40| 6d 69 6e 61 6e 63 65 2c | 4c 50 2d 3e 75 6e 69 74 |minance,|LP->unit|
|00004b50| 73 29 3b 0d 0d 09 2f 2a | 20 70 6c 61 6e 20 74 68 |s);.../*| plan th|
|00004b60| 65 20 6c 75 6d 69 6e 61 | 6e 63 65 20 61 6e 64 20 |e lumina|nce and |
|00004b70| 67 61 69 6e 20 6d 65 61 | 73 75 72 65 6d 65 6e 74 |gain mea|surement|
|00004b80| 73 20 2a 2f 0d 09 69 66 | 28 73 6b 69 70 52 47 42 |s */..if|(skipRGB|
|00004b90| 29 6e 4c 72 67 62 3d 30 | 3b 0d 09 72 65 61 64 54 |)nLrgb=0|;..readT|
|00004ba0| 6f 74 61 6c 3d 63 79 63 | 6c 65 73 2a 28 52 4f 55 |otal=cyc|les*(ROU|
|00004bb0| 4e 44 5f 4c 55 4d 49 4e | 41 4e 43 45 53 2b 33 2a |ND_LUMIN|ANCES+3*|
|00004bc0| 6e 4c 72 67 62 29 3b 0d | 09 70 72 69 6e 74 66 28 |nLrgb);.|.printf(|
|00004bd0| 22 4e 6f 77 20 74 61 6b | 69 6e 67 20 25 64 20 72 |"Now tak|ing %d r|
|00004be0| 65 61 64 69 6e 67 73 20 | 2e 20 2e 20 2e 5c 6e 22 |eadings |. . .\n"|
|00004bf0| 2c 72 65 61 64 54 6f 74 | 61 6c 29 3b 0d 09 66 6f |,readTot|al);..fo|
|00004c00| 72 20 28 69 3d 30 3b 69 | 3c 6e 4c 3b 69 2b 2b 29 |r (i=0;i|<nL;i++)|
|00004c10| 20 4c 5b 69 5d 3d 30 2e | 30 3b 0d 09 6b 3d 30 3b | L[i]=0.|0;..k=0;|
|00004c20| 0d 09 66 6f 72 20 28 69 | 3d 30 3b 69 3c 6e 4c 3b |..for (i|=0;i<nL;|
|00004c30| 69 2b 2b 29 7b 0d 09 09 | 56 5b 69 5d 3d 6b 3b 0d |i++){...|V[i]=k;.|
|00004c40| 09 09 69 66 28 6b 3d 3d | 4c 50 2d 3e 56 4d 61 78 |..if(k==|LP->VMax|
|00004c50| 29 20 7b 0d 09 09 09 69 | 66 28 69 2b 31 3c 6e 4c |) {....i|f(i+1<nL|
|00004c60| 29 20 56 5b 2b 2b 69 5d | 3d 6b 3b 09 2f 2a 20 70 |) V[++i]|=k;./* p|
|00004c70| 75 74 20 74 77 6f 20 70 | 6f 69 6e 74 73 20 61 74 |ut two p|oints at|
|00004c80| 20 56 4d 61 78 2c 20 62 | 65 63 61 75 73 65 20 69 | VMax, b|ecause i|
|00004c90| 74 27 73 20 69 6d 70 6f | 72 74 61 6e 74 20 2a 2f |t's impo|rtant */|
|00004ca0| 0d 09 09 09 6e 4c 3d 69 | 2b 31 3b 0d 09 09 09 62 |....nL=i|+1;....b|
|00004cb0| 72 65 61 6b 3b 0d 09 09 | 7d 0d 09 09 6b 20 2b 3d |reak;...|}...k +=|
|00004cc0| 20 28 4c 50 2d 3e 56 4d | 61 78 2b 31 29 2f 28 6e | (LP->VM|ax+1)/(n|
|00004cd0| 4c 2d 32 29 3b 0d 09 09 | 69 66 28 6b 3e 4c 50 2d |L-2);...|if(k>LP-|
|00004ce0| 3e 56 4d 61 78 29 6b 3d | 4c 50 2d 3e 56 4d 61 78 |>VMax)k=|LP->VMax|
|00004cf0| 3b 0d 09 7d 0d 09 66 6f | 72 20 28 6b 3d 30 3b 6b |;..}..fo|r (k=0;k|
|00004d00| 3c 33 3b 6b 2b 2b 29 66 | 6f 72 28 69 3d 30 3b 69 |<3;k++)f|or(i=0;i|
|00004d10| 3c 6e 4c 72 67 62 3b 69 | 2b 3d 32 29 7b 0d 09 09 |<nLrgb;i|+=2){...|
|00004d20| 66 6f 72 28 6a 3d 30 3b | 6a 3c 33 3b 6a 2b 2b 29 |for(j=0;|j<3;j++)|
|00004d30| 20 6e 72 67 62 5b 6b 5d | 5b 69 2b 31 5d 5b 6a 5d | nrgb[k]|[i+1][j]|
|00004d40| 3d 6e 72 67 62 5b 6b 5d | 5b 69 5d 5b 6a 5d 3d 28 |=nrgb[k]|[i][j]=(|
|00004d50| 4c 50 2d 3e 56 4d 61 78 | 2b 31 29 2a 28 30 2e 36 |LP->VMax|+1)*(0.6|
|00004d60| 36 37 2b 30 2e 33 33 33 | 2a 69 2f 6e 4c 72 67 62 |67+0.333|*i/nLrgb|
|00004d70| 29 3b 0d 09 09 6e 72 67 | 62 5b 6b 5d 5b 69 2b 31 |);...nrg|b[k][i+1|
|00004d80| 5d 5b 6b 5d 3d 4c 50 2d | 3e 56 4d 61 78 3b 0d 09 |][k]=LP-|>VMax;..|
|00004d90| 09 6e 72 67 62 5b 6b 5d | 5b 69 5d 5b 6b 5d 3d 30 |.nrgb[k]|[i][k]=0|
|00004da0| 3b 0d 09 09 69 66 28 6b | 3d 3d 32 29 20 6e 72 67 |;...if(k|==2) nrg|
|00004db0| 62 5b 6b 5d 5b 69 5d 5b | 6b 5d 3d 28 4c 50 2d 3e |b[k][i][|k]=(LP->|
|00004dc0| 56 4d 61 78 2b 31 29 2f | 32 3b 09 2f 2a 20 74 61 |VMax+1)/|2;./* ta|
|00004dd0| 6b 65 20 73 6d 61 6c 6c | 65 72 20 73 74 65 70 2c |ke small|er step,|
|00004de0| 20 62 65 63 61 75 73 65 | 20 62 6c 75 65 20 67 61 | because| blue ga|
|00004df0| 69 6e 20 69 73 20 68 69 | 67 68 65 73 74 20 2a 2f |in is hi|ghest */|
|00004e00| 0d 09 7d 0d 09 66 6f 72 | 28 6b 3d 30 3b 6b 3c 33 |..}..for|(k=0;k<3|
|00004e10| 3b 6b 2b 2b 29 66 6f 72 | 20 28 69 3d 30 3b 69 3c |;k++)for| (i=0;i<|
|00004e20| 6e 4c 72 67 62 3b 69 2b | 2b 29 4c 72 67 62 5b 6b |nLrgb;i+|+)Lrgb[k|
|00004e30| 5d 5b 69 5d 3d 30 2e 30 | 3b 0d 09 0d 09 2f 2a 20 |][i]=0.0|;..../* |
|00004e40| 6d 65 61 73 75 72 65 20 | 73 65 76 65 72 61 6c 20 |measure |several |
|00004e50| 74 69 6d 65 73 20 74 6f | 20 6d 69 6e 69 6d 69 7a |times to| minimiz|
|00004e60| 65 20 74 68 65 20 65 66 | 66 65 63 74 20 6f 66 20 |e the ef|fect of |
|00004e70| 6c 75 6d 69 6e 61 6e 63 | 65 20 64 72 69 66 74 20 |luminanc|e drift |
|00004e80| 2a 2f 0d 09 53 65 74 50 | 6f 72 74 28 77 69 6e 64 |*/..SetP|ort(wind|
|00004e90| 6f 77 29 3b 0d 09 42 72 | 69 6e 67 54 6f 46 72 6f |ow);..Br|ingToFro|
|00004ea0| 6e 74 28 77 69 6e 64 6f | 77 29 3b 0d 09 47 65 74 |nt(windo|w);..Get|
|00004eb0| 46 4e 75 6d 28 28 53 74 | 72 69 6e 67 50 74 72 29 |FNum((St|ringPtr)|
|00004ec0| 20 22 5c 70 4d 6f 6e 61 | 63 6f 22 2c 26 46 6f 6e | "\pMona|co",&Fon|
|00004ed0| 74 4e 75 6d 29 3b 0d 09 | 54 65 78 74 46 6f 6e 74 |tNum);..|TextFont|
|00004ee0| 28 46 6f 6e 74 4e 75 6d | 29 3b 0d 09 54 65 78 74 |(FontNum|);..Text|
|00004ef0| 53 69 7a 65 28 33 36 29 | 3b 0d 09 6d 79 52 65 63 |Size(36)|;..myRec|
|00004f00| 74 20 3d 20 77 69 6e 64 | 6f 77 2d 3e 70 6f 72 74 |t = wind|ow->port|
|00004f10| 52 65 63 74 3b 0d 09 62 | 6f 74 74 6f 6d 3d 6d 79 |Rect;..b|ottom=my|
|00004f20| 52 65 63 74 2e 62 6f 74 | 74 6f 6d 3b 0d 09 53 65 |Rect.bot|tom;..Se|
|00004f30| 74 52 65 63 74 28 26 54 | 65 73 74 52 65 63 74 2c |tRect(&T|estRect,|
|00004f40| 20 28 6d 79 52 65 63 74 | 2e 72 69 67 68 74 2b 6d | (myRect|.right+m|
|00004f50| 79 52 65 63 74 2e 6c 65 | 66 74 2d 74 65 73 74 53 |yRect.le|ft-testS|
|00004f60| 69 7a 65 29 2f 32 0d 09 | 09 2c 28 6d 79 52 65 63 |ize)/2..|.,(myRec|
|00004f70| 74 2e 74 6f 70 2b 6d 79 | 52 65 63 74 2e 62 6f 74 |t.top+my|Rect.bot|
|00004f80| 74 6f 6d 2d 74 65 73 74 | 53 69 7a 65 29 2f 32 0d |tom-test|Size)/2.|
|00004f90| 09 09 2c 28 6d 79 52 65 | 63 74 2e 72 69 67 68 74 |..,(myRe|ct.right|
|00004fa0| 2b 6d 79 52 65 63 74 2e | 6c 65 66 74 2b 74 65 73 |+myRect.|left+tes|
|00004fb0| 74 53 69 7a 65 29 2f 32 | 0d 09 09 2c 28 6d 79 52 |tSize)/2|...,(myR|
|00004fc0| 65 63 74 2e 74 6f 70 2b | 6d 79 52 65 63 74 2e 62 |ect.top+|myRect.b|
|00004fd0| 6f 74 74 6f 6d 2b 74 65 | 73 74 53 69 7a 65 29 2f |ottom+te|stSize)/|
|00004fe0| 32 20 29 3b 0d 09 0d 09 | 2f 2a 20 73 65 74 20 75 |2 );....|/* set u|
|00004ff0| 70 20 62 61 63 6b 67 72 | 6f 75 6e 64 20 2a 2f 0d |p backgr|ound */.|
|00005000| 09 4c 50 2d 3e 74 61 62 | 6c 65 5b 32 5d 2e 72 67 |.LP->tab|le[2].rg|
|00005010| 62 2e 72 65 64 20 3d 20 | 4c 50 2d 3e 74 61 62 6c |b.red = |LP->tabl|
|00005020| 65 5b 32 5d 2e 72 67 62 | 2e 67 72 65 65 6e 20 3d |e[2].rgb|.green =|
|00005030| 20 20 4c 50 2d 3e 74 61 | 62 6c 65 5b 32 5d 2e 72 | LP->ta|ble[2].r|
|00005040| 67 62 2e 62 6c 75 65 20 | 3d 20 0d 09 09 4c 50 2d |gb.blue |= ...LP-|
|00005050| 3e 56 42 61 63 6b 67 72 | 6f 75 6e 64 3c 3c 4c 50 |>VBackgr|ound<<LP|
|00005060| 2d 3e 6c 65 66 74 53 68 | 69 66 74 3b 0d 09 4c 6f |->leftSh|ift;..Lo|
|00005070| 61 64 4c 75 6d 69 6e 61 | 6e 63 65 73 28 64 65 76 |adLumina|nces(dev|
|00005080| 69 63 65 2c 4c 50 2c 31 | 2c 32 29 3b 09 2f 2a 20 |ice,LP,1|,2);./* |
|00005090| 6c 6f 61 64 20 62 61 63 | 6b 67 72 6f 75 6e 64 20 |load bac|kground |
|000050a0| 69 6e 74 6f 20 63 6c 75 | 74 20 2a 2f 0d 09 50 6d |into clu|t */..Pm|
|000050b0| 42 61 63 6b 43 6f 6c 6f | 72 28 32 29 3b 09 09 09 |BackColo|r(2);...|
|000050c0| 09 2f 2a 20 6f 75 72 20 | 62 61 63 6b 67 72 6f 75 |./* our |backgrou|
|000050d0| 6e 64 20 2a 2f 0d 09 45 | 72 61 73 65 52 65 63 74 |nd */..E|raseRect|
|000050e0| 28 26 6d 79 52 65 63 74 | 29 3b 0d 09 50 6d 42 61 |(&myRect|);..PmBa|
|000050f0| 63 6b 43 6f 6c 6f 72 28 | 31 29 3b 09 09 09 09 2f |ckColor(|1);..../|
|00005100| 2a 20 6f 75 72 20 74 65 | 73 74 20 6c 75 6d 69 6e |* our te|st lumin|
|00005110| 61 6e 63 65 20 2a 2f 0d | 09 45 72 61 73 65 4f 76 |ance */.|.EraseOv|
|00005120| 61 6c 28 26 54 65 73 74 | 52 65 63 74 29 3b 0d 09 |al(&Test|Rect);..|
|00005130| 46 6c 75 73 68 45 76 65 | 6e 74 73 28 65 76 65 72 |FlushEve|nts(ever|
|00005140| 79 45 76 65 6e 74 2c 30 | 29 3b 0d 09 72 65 61 64 |yEvent,0|);..read|
|00005150| 4e 75 6d 62 65 72 20 3d | 20 30 3b 09 2f 2a 20 69 |Number =| 0;./* i|
|00005160| 6e 69 74 69 61 6c 69 7a | 65 20 74 6f 20 63 6f 75 |nitializ|e to cou|
|00005170| 6e 74 20 74 68 65 20 6e | 75 6d 62 65 72 20 6f 66 |nt the n|umber of|
|00005180| 20 72 65 61 64 69 6e 67 | 20 2a 2f 0d 09 66 6f 72 | reading| */..for|
|00005190| 28 6a 3d 30 3b 6a 3c 63 | 79 63 6c 65 73 3b 6a 2b |(j=0;j<c|ycles;j+|
|000051a0| 2b 29 09 7b 0d 09 09 66 | 6f 72 20 28 6b 3d 2d 31 |+).{...f|or (k=-1|
|000051b0| 3b 6b 3c 33 3b 6b 2b 2b | 29 09 7b 0d 09 09 09 69 |;k<3;k++|).{....i|
|000051c0| 66 28 6b 3c 30 29 20 69 | 69 3d 6e 4c 3b 0d 09 09 |f(k<0) i|i=nL;...|
|000051d0| 09 65 6c 73 65 20 69 69 | 3d 6e 4c 72 67 62 3b 0d |.else ii|=nLrgb;.|
|000051e0| 09 09 09 66 6f 72 20 28 | 69 3d 30 3b 69 3c 69 69 |...for (|i=0;i<ii|
|000051f0| 3b 69 2b 2b 29 7b 0d 09 | 09 09 09 2f 2a 20 73 65 |;i++){..|.../* se|
|00005200| 74 20 75 70 20 74 65 73 | 74 20 2a 2f 0d 09 09 09 |t up tes|t */....|
|00005210| 09 53 65 74 52 65 63 74 | 28 26 6c 61 62 65 6c 52 |.SetRect|(&labelR|
|00005220| 65 63 74 2c 30 2c 62 6f | 74 74 6f 6d 2d 34 30 2c |ect,0,bo|ttom-40,|
|00005230| 33 30 30 2c 62 6f 74 74 | 6f 6d 29 3b 0d 09 09 09 |300,bott|om);....|
|00005240| 09 53 65 74 50 6f 72 74 | 28 77 69 6e 64 6f 77 29 |.SetPort|(window)|
|00005250| 3b 0d 09 09 09 09 50 6d | 42 61 63 6b 43 6f 6c 6f |;.....Pm|BackColo|
|00005260| 72 28 32 29 3b 0d 09 09 | 09 09 45 72 61 73 65 52 |r(2);...|..EraseR|
|00005270| 65 63 74 28 26 6c 61 62 | 65 6c 52 65 63 74 29 3b |ect(&lab|elRect);|
|00005280| 0d 09 09 09 09 50 6d 46 | 6f 72 65 43 6f 6c 6f 72 |.....PmF|oreColor|
|00005290| 28 63 74 53 69 7a 65 29 | 3b 09 09 09 09 2f 2a 20 |(ctSize)|;..../* |
|000052a0| 62 6c 61 63 6b 20 2a 2f | 0d 09 09 09 09 4d 6f 76 |black */|.....Mov|
|000052b0| 65 54 6f 28 30 2c 62 6f | 74 74 6f 6d 29 3b 0d 09 |eTo(0,bo|ttom);..|
|000052c0| 09 09 09 69 66 28 6b 3c | 30 29 20 44 72 61 77 50 |...if(k<|0) DrawP|
|000052d0| 72 69 6e 74 66 28 22 25 | 33 64 22 2c 56 5b 69 5d |rintf("%|3d",V[i]|
|000052e0| 29 3b 0d 09 09 09 09 65 | 6c 73 65 20 44 72 61 77 |);.....e|lse Draw|
|000052f0| 50 72 69 6e 74 66 28 22 | 25 33 64 25 34 64 25 34 |Printf("|%3d%4d%4|
|00005300| 64 22 2c 6b 2c 6e 72 67 | 62 5b 6b 5d 5b 69 5d 5b |d",k,nrg|b[k][i][|
|00005310| 30 5d 2c 6e 72 67 62 5b | 6b 5d 5b 69 5d 5b 31 5d |0],nrgb[|k][i][1]|
|00005320| 2c 6e 72 67 62 5b 6b 5d | 5b 69 5d 5b 32 5d 29 3b |,nrgb[k]|[i][2]);|
|00005330| 0d 09 09 09 09 53 65 74 | 50 6f 72 74 28 6f 6c 64 |.....Set|Port(old|
|00005340| 57 69 6e 64 6f 77 29 3b | 0d 09 09 09 09 72 65 61 |Window);|.....rea|
|00005350| 64 4e 75 6d 62 65 72 2b | 2b 3b 0d 09 09 09 09 69 |dNumber+|+;.....i|
|00005360| 66 28 21 61 75 74 6f 6d | 61 74 69 63 29 7b 0d 09 |f(!autom|atic){..|
|00005370| 09 09 09 09 70 72 69 6e | 74 66 28 22 25 64 20 6f |....prin|tf("%d o|
|00005380| 75 74 20 6f 66 20 25 64 | 20 72 65 61 64 69 6e 67 |ut of %d| reading|
|00005390| 73 3a 5c 74 22 2c 72 65 | 61 64 4e 75 6d 62 65 72 |s:\t",re|adNumber|
|000053a0| 2c 72 65 61 64 54 6f 74 | 61 6c 29 3b 09 0d 09 09 |,readTot|al);....|
|000053b0| 09 09 7d 0d 09 09 09 09 | 69 66 28 6b 3c 30 29 20 |..}.....|if(k<0) |
|000053c0| 7b 0d 09 09 09 09 09 6c | 75 6d 69 6e 61 6e 63 65 |{......l|uminance|
|000053d0| 3d 47 65 74 41 4c 75 6d | 69 6e 61 6e 63 65 28 4c |=GetALum|inance(L|
|000053e0| 50 2c 64 65 76 69 63 65 | 2c 66 72 61 6d 65 73 2c |P,device|,frames,|
|000053f0| 4c 75 6d 69 6e 61 6e 63 | 65 50 65 72 56 6f 6c 74 |Luminanc|ePerVolt|
|00005400| 61 67 65 2c 31 0d 09 09 | 09 09 09 09 2c 56 5b 69 |age,1...|....,V[i|
|00005410| 5d 2c 56 5b 69 5d 2c 56 | 5b 69 5d 29 3b 0d 09 09 |],V[i],V|[i]);...|
|00005420| 09 09 09 6c 75 6d 69 6e | 61 6e 63 65 2d 3d 64 61 |...lumin|ance-=da|
|00005430| 72 6b 4c 75 6d 69 6e 61 | 6e 63 65 3b 0d 09 09 09 |rkLumina|nce;....|
|00005440| 09 09 4c 5b 69 5d 20 2b | 3d 20 6c 75 6d 69 6e 61 |..L[i] +|= lumina|
|00005450| 6e 63 65 2f 63 79 63 6c | 65 73 3b 0d 09 09 09 09 |nce/cycl|es;.....|
|00005460| 7d 0d 09 09 09 09 65 6c | 73 65 20 7b 0d 09 09 09 |}.....el|se {....|
|00005470| 09 09 6c 75 6d 69 6e 61 | 6e 63 65 3d 47 65 74 41 |..lumina|nce=GetA|
|00005480| 4c 75 6d 69 6e 61 6e 63 | 65 28 4c 50 2c 64 65 76 |Luminanc|e(LP,dev|
|00005490| 69 63 65 2c 66 72 61 6d | 65 73 2c 4c 75 6d 69 6e |ice,fram|es,Lumin|
|000054a0| 61 6e 63 65 50 65 72 56 | 6f 6c 74 61 67 65 2c 31 |ancePerV|oltage,1|
|000054b0| 0d 09 09 09 09 09 09 2c | 6e 72 67 62 5b 6b 5d 5b |.......,|nrgb[k][|
|000054c0| 69 5d 5b 30 5d 2c 6e 72 | 67 62 5b 6b 5d 5b 69 5d |i][0],nr|gb[k][i]|
|000054d0| 5b 31 5d 2c 6e 72 67 62 | 5b 6b 5d 5b 69 5d 5b 32 |[1],nrgb|[k][i][2|
|000054e0| 5d 29 3b 0d 09 09 09 09 | 09 6c 75 6d 69 6e 61 6e |]);.....|.luminan|
|000054f0| 63 65 2d 3d 64 61 72 6b | 4c 75 6d 69 6e 61 6e 63 |ce-=dark|Luminanc|
|00005500| 65 3b 0d 09 09 09 09 09 | 4c 72 67 62 5b 6b 5d 5b |e;......|Lrgb[k][|
|00005510| 69 5d 20 2b 3d 20 6c 75 | 6d 69 6e 61 6e 63 65 2f |i] += lu|minance/|
|00005520| 63 79 63 6c 65 73 3b 0d | 09 09 09 09 7d 0d 09 09 |cycles;.|....}...|
|00005530| 09 7d 0d 09 09 7d 0d 09 | 7d 0d 09 47 44 44 69 73 |.}...}..|}..GDDis|
|00005540| 70 6f 73 65 57 69 6e 64 | 6f 77 31 28 77 69 6e 64 |poseWind|ow1(wind|
|00005550| 6f 77 29 3b 0d 09 53 65 | 74 50 6f 72 74 28 6f 6c |ow);..Se|tPort(ol|
|00005560| 64 57 69 6e 64 6f 77 29 | 3b 0d 09 53 65 74 47 44 |dWindow)|;..SetGD|
|00005570| 65 76 69 63 65 28 6f 6c | 64 44 65 76 69 63 65 29 |evice(ol|dDevice)|
|00005580| 3b 0d 09 0d 09 2f 2a 20 | 70 6f 6c 79 6e 6f 6d 69 |;..../* |polynomi|
|00005590| 61 6c 20 61 6e 64 20 71 | 75 61 64 72 61 74 69 63 |al and q|uadratic|
|000055a0| 20 66 69 74 73 20 2a 2f | 0d 09 6d 61 3d 4d 41 58 | fits */|..ma=MAX|
|000055b0| 5f 43 4f 45 46 46 49 43 | 49 45 4e 54 53 3b 0d 09 |_COEFFIC|IENTS;..|
|000055c0| 78 3d 76 65 63 74 6f 72 | 28 31 2c 6e 4c 29 3b 0d |x=vector|(1,nL);.|
|000055d0| 09 79 3d 76 65 63 74 6f | 72 28 31 2c 6e 4c 29 3b |.y=vecto|r(1,nL);|
|000055e0| 0d 09 73 69 67 3d 76 65 | 63 74 6f 72 28 31 2c 6e |..sig=ve|ctor(1,n|
|000055f0| 4c 29 3b 0d 09 61 3d 76 | 65 63 74 6f 72 28 31 2c |L);..a=v|ector(1,|
|00005600| 6e 4c 29 3b 0d 09 75 3d | 6d 61 74 72 69 78 28 31 |nL);..u=|matrix(1|
|00005610| 2c 6e 4c 2c 31 2c 6d 61 | 29 3b 0d 09 76 3d 6d 61 |,nL,1,ma|);..v=ma|
|00005620| 74 72 69 78 28 31 2c 6d | 61 2c 31 2c 6d 61 29 3b |trix(1,m|a,1,ma);|
|00005630| 0d 09 77 3d 76 65 63 74 | 6f 72 28 31 2c 6d 61 29 |..w=vect|or(1,ma)|
|00005640| 3b 0d 09 63 76 6d 3d 6d | 61 74 72 69 78 28 31 2c |;..cvm=m|atrix(1,|
|00005650| 6d 61 2c 31 2c 6d 61 29 | 3b 0d 09 66 6f 72 28 69 |ma,1,ma)|;..for(i|
|00005660| 3d 30 3b 69 3c 6e 4c 3b | 69 2b 2b 29 7b 0d 09 09 |=0;i<nL;|i++){...|
|00005670| 78 5b 69 2b 31 5d 3d 56 | 5b 69 5d 3b 0d 09 09 79 |x[i+1]=V|[i];...y|
|00005680| 5b 69 2b 31 5d 3d 4c 5b | 69 5d 3b 0d 09 09 73 69 |[i+1]=L[|i];...si|
|00005690| 67 5b 69 2b 31 5d 3d 31 | 30 2e 30 3b 0d 09 7d 0d |g[i+1]=1|0.0;..}.|
|000056a0| 09 73 76 64 66 69 74 28 | 78 2c 79 2c 73 69 67 2c |.svdfit(|x,y,sig,|
|000056b0| 6e 4c 2c 61 2c 6d 61 2c | 75 2c 76 2c 77 2c 26 63 |nL,a,ma,|u,v,w,&c|
|000056c0| 68 69 73 71 2c 66 70 6f | 6c 79 29 3b 09 2f 2a 20 |hisq,fpo|ly);./* |
|000056d0| 6d 61 2d 31 74 68 20 6f | 72 64 65 72 20 70 6f 6c |ma-1th o|rder pol|
|000056e0| 79 6e 6f 6d 69 61 6c 20 | 63 75 72 76 65 20 66 69 |ynomial |curve fi|
|000056f0| 74 20 2a 2f 0d 09 73 76 | 64 76 61 72 28 76 2c 6d |t */..sv|dvar(v,m|
|00005700| 61 2c 77 2c 63 76 6d 29 | 3b 0d 09 69 66 28 6d 61 |a,w,cvm)|;..if(ma|
|00005710| 3e 4d 41 58 5f 43 4f 45 | 46 46 49 43 49 45 4e 54 |>MAX_COE|FFICIENT|
|00005720| 53 29 50 72 69 6e 74 66 | 45 78 69 74 28 22 45 72 |S)Printf|Exit("Er|
|00005730| 72 6f 72 3a 20 74 6f 6f | 20 6d 61 6e 79 20 63 6f |ror: too| many co|
|00005740| 65 66 66 69 63 69 65 6e | 74 73 5c 30 30 37 5c 6e |efficien|ts\007\n|
|00005750| 22 29 3b 0d 09 4c 50 2d | 3e 63 6f 65 66 66 69 63 |");..LP-|>coeffic|
|00005760| 69 65 6e 74 73 3d 6d 61 | 3b 0d 09 66 6f 72 28 69 |ients=ma|;..for(i|
|00005770| 3d 30 3b 69 3c 6d 61 3b | 69 2b 2b 29 20 4c 50 2d |=0;i<ma;|i++) LP-|
|00005780| 3e 70 5b 69 5d 3d 61 5b | 69 2b 31 5d 3b 0d 09 70 |>p[i]=a[|i+1];..p|
|00005790| 72 69 6e 74 66 28 22 4c | 28 56 29 20 3d 22 29 3b |rintf("L|(V) =");|
|000057a0| 0d 09 66 6f 72 28 69 3d | 30 3b 69 3c 6d 61 3b 69 |..for(i=|0;i<ma;i|
|000057b0| 2b 2b 29 20 70 72 69 6e | 74 66 28 22 20 2b 20 25 |++) prin|tf(" + %|
|000057c0| 36 67 20 56 5e 25 64 22 | 2c 61 5b 69 2b 31 5d 2c |6g V^%d"|,a[i+1],|
|000057d0| 69 29 3b 0d 09 70 72 69 | 6e 74 66 28 22 2e 20 20 |i);..pri|ntf(". |
|000057e0| 63 68 69 73 71 20 25 67 | 5c 6e 22 2c 63 68 69 73 |chisq %g|\n",chis|
|000057f0| 71 29 3b 0d 09 73 76 64 | 66 69 74 28 78 2c 79 2c |q);..svd|fit(x,y,|
|00005800| 73 69 67 2c 6e 4c 2c 61 | 2c 33 2c 75 2c 76 2c 77 |sig,nL,a|,3,u,v,w|
|00005810| 2c 26 63 68 69 73 71 2c | 66 70 6f 6c 79 29 3b 09 |,&chisq,|fpoly);.|
|00005820| 2f 2a 20 32 6e 64 20 6f | 72 64 65 72 20 70 6f 6c |/* 2nd o|rder pol|
|00005830| 79 6e 6f 6d 69 61 6c 20 | 63 75 72 76 65 20 66 69 |ynomial |curve fi|
|00005840| 74 20 2a 2f 0d 09 73 76 | 64 76 61 72 28 76 2c 33 |t */..sv|dvar(v,3|
|00005850| 2c 77 2c 63 76 6d 29 3b | 0d 09 70 72 69 6e 74 66 |,w,cvm);|..printf|
|00005860| 28 22 5c 6e 71 75 61 64 | 72 61 74 69 63 20 66 69 |("\nquad|ratic fi|
|00005870| 74 3a 5c 6e 5c 6e 22 29 | 3b 0d 09 66 6f 72 28 69 |t:\n\n")|;..for(i|
|00005880| 3d 30 3b 69 3c 33 3b 69 | 2b 2b 29 20 4c 50 2d 3e |=0;i<3;i|++) LP->|
|00005890| 71 5b 69 5d 3d 61 5b 69 | 2b 31 5d 3b 0d 09 70 72 |q[i]=a[i|+1];..pr|
|000058a0| 69 6e 74 66 28 22 4c 28 | 56 29 20 3d 22 29 3b 0d |intf("L(|V) =");.|
|000058b0| 09 66 6f 72 28 69 3d 30 | 3b 69 3c 33 3b 69 2b 2b |.for(i=0|;i<3;i++|
|000058c0| 29 20 70 72 69 6e 74 66 | 28 22 20 2b 20 25 67 20 |) printf|(" + %g |
|000058d0| 56 5e 25 64 22 2c 61 5b | 69 2b 31 5d 2c 69 29 3b |V^%d",a[|i+1],i);|
|000058e0| 0d 09 70 72 69 6e 74 66 | 28 22 2e 20 20 63 68 69 |..printf|(". chi|
|000058f0| 73 71 20 25 67 5c 6e 22 | 2c 63 68 69 73 71 29 3b |sq %g\n"|,chisq);|
|00005900| 0d 09 66 72 65 65 5f 76 | 65 63 74 6f 72 28 78 2c |..free_v|ector(x,|
|00005910| 31 2c 6e 4c 29 3b 0d 09 | 66 72 65 65 5f 76 65 63 |1,nL);..|free_vec|
|00005920| 74 6f 72 28 79 2c 31 2c | 6e 4c 29 3b 0d 09 66 72 |tor(y,1,|nL);..fr|
|00005930| 65 65 5f 76 65 63 74 6f | 72 28 73 69 67 2c 31 2c |ee_vecto|r(sig,1,|
|00005940| 6e 4c 29 3b 0d 09 66 72 | 65 65 5f 76 65 63 74 6f |nL);..fr|ee_vecto|
|00005950| 72 28 61 2c 31 2c 6e 4c | 29 3b 0d 09 66 72 65 65 |r(a,1,nL|);..free|
|00005960| 5f 6d 61 74 72 69 78 28 | 75 2c 31 2c 6e 4c 2c 31 |_matrix(|u,1,nL,1|
|00005970| 2c 6d 61 29 3b 0d 09 66 | 72 65 65 5f 6d 61 74 72 |,ma);..f|ree_matr|
|00005980| 69 78 28 76 2c 31 2c 6d | 61 2c 31 2c 6d 61 29 3b |ix(v,1,m|a,1,ma);|
|00005990| 0d 09 66 72 65 65 5f 76 | 65 63 74 6f 72 28 77 2c |..free_v|ector(w,|
|000059a0| 31 2c 6d 61 29 3b 0d 09 | 66 72 65 65 5f 6d 61 74 |1,ma);..|free_mat|
|000059b0| 72 69 78 28 63 76 6d 2c | 31 2c 6d 61 2c 31 2c 6d |rix(cvm,|1,ma,1,m|
|000059c0| 61 29 3b 0d 09 65 3d 30 | 2e 30 3b 0d 09 66 6f 72 |a);..e=0|.0;..for|
|000059d0| 28 69 3d 30 3b 69 3c 6e | 4c 3b 69 2b 2b 29 7b 0d |(i=0;i<n|L;i++){.|
|000059e0| 09 09 66 3d 30 2e 30 3b | 0d 09 09 56 56 3d 31 2e |..f=0.0;|...VV=1.|
|000059f0| 30 3b 0d 09 09 66 6f 72 | 28 6a 3d 30 3b 6a 3c 4c |0;...for|(j=0;j<L|
|00005a00| 50 2d 3e 63 6f 65 66 66 | 69 63 69 65 6e 74 73 3b |P->coeff|icients;|
|00005a10| 6a 2b 2b 29 7b 0d 09 09 | 09 66 2b 3d 4c 50 2d 3e |j++){...|.f+=LP->|
|00005a20| 70 5b 6a 5d 2a 56 56 3b | 0d 09 09 09 56 56 2a 3d |p[j]*VV;|....VV*=|
|00005a30| 56 5b 69 5d 3b 0d 09 09 | 7d 0d 09 09 65 2b 3d 28 |V[i];...|}...e+=(|
|00005a40| 4c 5b 69 5d 2d 66 29 2a | 28 4c 5b 69 5d 2d 66 29 |L[i]-f)*|(L[i]-f)|
|00005a50| 3b 0d 09 7d 0d 09 4c 50 | 2d 3e 70 6f 6c 79 6e 6f |;..}..LP|->polyno|
|00005a60| 6d 69 61 6c 45 72 72 6f | 72 20 3d 20 73 71 72 74 |mialErro|r = sqrt|
|00005a70| 28 65 2f 6e 4c 29 3b 0d | 09 65 3d 30 2e 30 3b 0d |(e/nL);.|.e=0.0;.|
|00005a80| 09 66 6f 72 28 69 3d 30 | 3b 69 3c 6e 4c 3b 69 2b |.for(i=0|;i<nL;i+|
|00005a90| 2b 29 7b 0d 09 09 66 3d | 30 2e 30 3b 0d 09 09 56 |+){...f=|0.0;...V|
|00005aa0| 56 3d 31 2e 30 3b 0d 09 | 09 66 6f 72 28 6a 3d 30 |V=1.0;..|.for(j=0|
|00005ab0| 3b 6a 3c 33 3b 6a 2b 2b | 29 7b 0d 09 09 09 66 2b |;j<3;j++|){....f+|
|00005ac0| 3d 4c 50 2d 3e 71 5b 6a | 5d 2a 56 56 3b 0d 09 09 |=LP->q[j|]*VV;...|
|00005ad0| 09 56 56 2a 3d 56 5b 69 | 5d 3b 0d 09 09 7d 0d 09 |.VV*=V[i|];...}..|
|00005ae0| 09 65 2b 3d 28 4c 5b 69 | 5d 2d 66 29 2a 28 4c 5b |.e+=(L[i|]-f)*(L[|
|00005af0| 69 5d 2d 66 29 3b 0d 09 | 7d 0d 09 4c 50 2d 3e 71 |i]-f);..|}..LP->q|
|00005b00| 75 61 64 72 61 74 69 63 | 45 72 72 6f 72 20 3d 20 |uadratic|Error = |
|00005b10| 73 71 72 74 28 65 2f 6e | 4c 29 3b 0d 09 0d 09 2f |sqrt(e/n|L);..../|
|00005b20| 2a 20 70 6f 77 65 72 20 | 6c 61 77 20 66 69 74 20 |* power |law fit |
|00005b30| 2a 2f 0d 09 2f 2a 20 4c | 3d 70 5b 31 5d 2b 52 65 |*/../* L|=p[1]+Re|
|00005b40| 63 74 69 66 79 28 70 5b | 32 5d 2b 70 5b 33 5d 2a |ctify(p[|2]+p[3]*|
|00005b50| 56 29 5e 70 5b 34 5d 20 | 2a 2f 0d 09 70 3d 76 65 |V)^p[4] |*/..p=ve|
|00005b60| 63 74 6f 72 28 31 2c 34 | 29 3b 09 2f 2a 20 69 6e |ctor(1,4|);./* in|
|00005b70| 69 74 69 61 6c 20 73 74 | 61 72 74 69 6e 67 20 70 |itial st|arting p|
|00005b80| 6f 69 6e 74 20 2a 2f 0d | 09 2f 2a 0d 09 09 49 74 |oint */.|./*...It|
|00005b90| 20 69 73 20 6e 65 63 65 | 73 73 61 72 79 20 74 6f | is nece|ssary to|
|00005ba0| 20 68 61 76 65 20 61 20 | 72 65 61 73 6f 6e 61 62 | have a |reasonab|
|00005bb0| 6c 65 20 73 74 61 72 74 | 69 6e 67 20 70 6f 69 6e |le start|ing poin|
|00005bc0| 74 20 6f 72 20 74 68 65 | 20 73 65 61 72 63 68 20 |t or the| search |
|00005bd0| 63 61 6e 20 67 65 74 0d | 09 09 73 74 75 63 6b 20 |can get.|..stuck |
|00005be0| 6f 75 74 20 69 6e 20 74 | 68 65 20 62 6f 6f 6e 64 |out in t|he boond|
|00005bf0| 6f 63 6b 73 2e 20 53 69 | 6e 63 65 20 74 68 65 20 |ocks. Si|nce the |
|00005c00| 73 65 61 72 63 68 20 69 | 73 20 71 75 69 74 65 20 |search i|s quite |
|00005c10| 73 6c 6f 77 20 69 74 20 | 69 73 20 64 65 73 69 72 |slow it |is desir|
|00005c20| 61 62 6c 65 20 74 6f 0d | 09 09 67 69 76 65 20 69 |able to.|..give i|
|00005c30| 74 20 61 73 20 67 6f 6f | 64 20 61 20 73 74 61 72 |t as goo|d a star|
|00005c40| 74 69 6e 67 20 70 6f 69 | 6e 74 20 61 73 20 70 6f |ting poi|nt as po|
|00005c50| 73 73 69 62 6c 65 2e 20 | 54 68 65 72 65 66 6f 72 |ssible. |Therefor|
|00005c60| 65 20 49 20 6d 61 6b 65 | 20 75 73 65 20 6f 66 20 |e I make| use of |
|00005c70| 74 68 65 0d 09 09 71 75 | 61 64 72 61 74 69 63 20 |the...qu|adratic |
|00005c80| 66 69 74 20 74 6f 20 74 | 72 79 20 74 6f 20 67 69 |fit to t|ry to gi|
|00005c90| 76 65 20 69 74 20 61 20 | 70 72 65 74 74 79 20 67 |ve it a |pretty g|
|00005ca0| 6f 6f 64 20 73 74 61 72 | 74 69 6e 67 20 70 6f 69 |ood star|ting poi|
|00005cb0| 6e 74 2e 0d 09 2a 2f 0d | 09 2f 2a 20 75 73 65 20 |nt...*/.|./* use |
|00005cc0| 74 68 65 20 71 75 61 64 | 72 61 74 69 63 20 66 69 |the quad|ratic fi|
|00005cd0| 74 20 61 73 20 74 68 65 | 20 73 74 61 72 74 69 6e |t as the| startin|
|00005ce0| 67 20 70 6f 69 6e 74 20 | 2a 2f 0d 09 70 5b 31 5d |g point |*/..p[1]|
|00005cf0| 3d 4c 50 2d 3e 71 5b 30 | 5d 2d 30 2e 32 35 2a 4c |=LP->q[0|]-0.25*L|
|00005d00| 50 2d 3e 71 5b 31 5d 2a | 4c 50 2d 3e 71 5b 31 5d |P->q[1]*|LP->q[1]|
|00005d10| 2f 4c 50 2d 3e 71 5b 32 | 5d 3b 0d 09 70 5b 32 5d |/LP->q[2|];..p[2]|
|00005d20| 3d 30 2e 35 2a 4c 50 2d | 3e 71 5b 31 5d 2f 73 71 |=0.5*LP-|>q[1]/sq|
|00005d30| 72 74 28 4c 50 2d 3e 71 | 5b 32 5d 29 3b 0d 09 70 |rt(LP->q|[2]);..p|
|00005d40| 5b 33 5d 3d 73 71 72 74 | 28 4c 50 2d 3e 71 5b 32 |[3]=sqrt|(LP->q[2|
|00005d50| 5d 29 3b 0d 09 70 5b 34 | 5d 3d 32 2e 30 3b 0d 09 |]);..p[4|]=2.0;..|
|00005d60| 2f 2a 0d 09 09 4f 6e 20 | 73 65 63 6f 6e 64 20 74 |/*...On |second t|
|00005d70| 68 6f 75 67 68 74 2c 20 | 74 72 79 20 73 74 61 72 |hought, |try star|
|00005d80| 74 69 6e 67 20 77 69 74 | 68 20 61 20 67 61 6d 6d |ting wit|h a gamm|
|00005d90| 61 20 6f 66 20 32 2e 33 | 2e 0d 09 09 53 65 74 20 |a of 2.3|....Set |
|00005da0| 74 68 65 20 6c 75 6d 69 | 6e 61 6e 63 65 20 6f 66 |the lumi|nance of|
|00005db0| 66 73 65 74 20 70 5b 31 | 5d 20 74 6f 20 74 68 65 |fset p[1|] to the|
|00005dc0| 20 6d 65 61 73 75 72 65 | 64 20 64 63 20 6c 65 76 | measure|d dc lev|
|00005dd0| 65 6c 2e 0d 09 09 53 65 | 74 20 74 68 65 20 62 72 |el....Se|t the br|
|00005de0| 69 67 68 74 6e 65 73 73 | 20 70 5b 32 5d 20 73 6f |ightness| p[2] so|
|00005df0| 20 61 73 20 74 6f 20 6d | 61 74 63 68 20 74 68 65 | as to m|atch the|
|00005e00| 20 6e 75 6d 62 65 72 20 | 6f 66 66 73 65 74 20 69 | number |offset i|
|00005e10| 6e 20 74 68 65 20 71 75 | 61 64 72 61 74 69 63 20 |n the qu|adratic |
|00005e20| 66 69 74 2e 0d 09 09 53 | 65 74 20 74 68 65 20 63 |fit....S|et the c|
|00005e30| 6f 6e 74 72 61 73 74 20 | 70 5b 33 5d 20 73 6f 20 |ontrast |p[3] so |
|00005e40| 61 73 20 74 6f 20 66 69 | 74 20 74 68 65 20 6d 61 |as to fi|t the ma|
|00005e50| 78 69 6d 75 6d 20 64 61 | 74 61 20 70 6f 69 6e 74 |ximum da|ta point|
|00005e60| 2e 0d 09 09 53 65 74 20 | 67 61 6d 6d 61 20 70 5b |....Set |gamma p[|
|00005e70| 34 5d 20 74 6f 20 32 2e | 33 0d 09 2a 2f 0d 09 70 |4] to 2.|3..*/..p|
|00005e80| 5b 31 5d 3d 4c 5b 31 5d | 3b 0d 09 70 5b 32 5d 3d |[1]=L[1]|;..p[2]=|
|00005e90| 30 2e 35 2a 4c 50 2d 3e | 71 5b 31 5d 2f 73 71 72 |0.5*LP->|q[1]/sqr|
|00005ea0| 74 28 4c 50 2d 3e 71 5b | 32 5d 29 3b 0d 09 70 5b |t(LP->q[|2]);..p[|
|00005eb0| 34 5d 3d 32 2e 33 3b 0d | 09 70 5b 33 5d 3d 28 70 |4]=2.3;.|.p[3]=(p|
|00005ec0| 6f 77 28 4c 5b 6e 4c 2d | 31 5d 2d 70 5b 31 5d 2c |ow(L[nL-|1]-p[1],|
|00005ed0| 31 2e 30 2f 70 5b 34 5d | 29 2d 70 5b 32 5d 29 2f |1.0/p[4]|)-p[2])/|
|00005ee0| 56 5b 6e 4c 2d 31 5d 3b | 0d 09 70 5b 32 5d 3d 70 |V[nL-1];|..p[2]=p|
|00005ef0| 5b 33 5d 2a 30 2e 35 2a | 4c 50 2d 3e 71 5b 31 5d |[3]*0.5*|LP->q[1]|
|00005f00| 2f 4c 50 2d 3e 71 5b 32 | 5d 3b 0d 09 70 5b 33 5d |/LP->q[2|];..p[3]|
|00005f10| 3d 28 70 6f 77 28 4c 5b | 6e 4c 2d 31 5d 2d 70 5b |=(pow(L[|nL-1]-p[|
|00005f20| 31 5d 2c 31 2e 30 2f 70 | 5b 34 5d 29 2d 70 5b 32 |1],1.0/p|[4])-p[2|
|00005f30| 5d 29 2f 56 5b 6e 4c 2d | 31 5d 3b 0d 09 78 69 3d |])/V[nL-|1];..xi=|
|00005f40| 6d 61 74 72 69 78 28 31 | 2c 34 2c 31 2c 34 29 3b |matrix(1|,4,1,4);|
|00005f50| 09 2f 2a 20 69 6e 69 74 | 69 61 6c 20 73 65 74 20 |./* init|ial set |
|00005f60| 6f 66 20 64 69 72 65 63 | 74 69 6f 6e 73 20 2a 2f |of direc|tions */|
|00005f70| 0d 09 66 6f 72 28 69 3d | 31 3b 69 3c 3d 34 3b 69 |..for(i=|1;i<=4;i|
|00005f80| 2b 2b 29 66 6f 72 28 6a | 3d 31 3b 6a 3c 3d 34 3b |++)for(j|=1;j<=4;|
|00005f90| 6a 2b 2b 29 78 69 5b 69 | 5d 5b 6a 5d 3d 30 2e 30 |j++)xi[i|][j]=0.0|
|00005fa0| 3b 0d 09 78 69 5b 31 5d | 5b 31 5d 3d 30 2e 31 3b |;..xi[1]|[1]=0.1;|
|00005fb0| 0d 09 78 69 5b 32 5d 5b | 32 5d 3d 31 2e 30 3b 0d |..xi[2][|2]=1.0;.|
|00005fc0| 09 78 69 5b 33 5d 5b 33 | 5d 3d 30 2e 31 3b 0d 09 |.xi[3][3|]=0.1;..|
|00005fd0| 78 69 5b 34 5d 5b 34 5d | 3d 30 2e 30 31 3b 0d 09 |xi[4][4]|=0.01;..|
|00005fe0| 66 74 6f 6c 3d 31 65 2d | 32 3b 09 2f 2a 20 66 72 |ftol=1e-|2;./* fr|
|00005ff0| 61 63 74 69 6f 6e 61 6c | 20 74 6f 6c 65 72 61 6e |actional| toleran|
|00006000| 63 65 20 6f 6e 20 66 75 | 6e 63 74 69 6f 6e 20 76 |ce on fu|nction v|
|00006010| 61 6c 75 65 20 77 68 65 | 6e 20 64 6f 6e 65 20 2a |alue whe|n done *|
|00006020| 2f 0d 09 70 72 69 6e 74 | 66 28 22 5c 6e 70 6f 77 |/..print|f("\npow|
|00006030| 65 72 20 6c 61 77 20 66 | 69 74 3a 5c 6e 5c 6e 22 |er law f|it:\n\n"|
|00006040| 29 3b 0d 09 76 61 72 69 | 61 62 6c 65 73 3d 34 3b |);..vari|ables=4;|
|00006050| 09 2f 2a 20 69 6e 66 6f | 72 6d 20 50 6f 77 65 72 |./* info|rm Power|
|00006060| 52 4d 53 45 72 72 6f 72 | 20 2a 2f 0d 09 66 72 65 |RMSError| */..fre|
|00006070| 74 3d 50 6f 77 65 72 52 | 4d 53 45 72 72 6f 72 28 |t=PowerR|MSError(|
|00006080| 70 29 3b 0d 09 70 72 69 | 6e 74 66 28 22 4c 28 56 |p);..pri|ntf("L(V|
|00006090| 29 20 3d 20 25 39 2e 34 | 66 20 2b 20 52 65 63 74 |) = %9.4|f + Rect|
|000060a0| 69 66 79 28 25 39 2e 34 | 66 20 2b 20 25 39 2e 34 |ify(%9.4|f + %9.4|
|000060b0| 66 20 56 29 5e 25 39 2e | 34 66 20 b1 20 25 39 2e |f V)^%9.|4f . %9.|
|000060c0| 34 66 5c 6e 22 2c 70 5b | 31 5d 2c 70 5b 32 5d 2c |4f\n",p[|1],p[2],|
|000060d0| 70 5b 33 5d 2c 70 5b 34 | 5d 2c 66 72 65 74 29 3b |p[3],p[4|],fret);|
|000060e0| 0d 09 70 6f 77 65 6c 6c | 28 70 2c 78 69 2c 34 2c |..powell|(p,xi,4,|
|000060f0| 66 74 6f 6c 2c 26 69 74 | 65 72 2c 26 66 72 65 74 |ftol,&it|er,&fret|
|00006100| 2c 26 50 6f 77 65 72 52 | 4d 53 45 72 72 6f 72 29 |,&PowerR|MSError)|
|00006110| 3b 0d 09 70 72 69 6e 74 | 66 28 22 4c 28 56 29 20 |;..print|f("L(V) |
|00006120| 3d 20 25 39 2e 34 66 20 | 2b 20 52 65 63 74 69 66 |= %9.4f |+ Rectif|
|00006130| 79 28 25 39 2e 34 66 20 | 2b 20 25 39 2e 34 66 20 |y(%9.4f |+ %9.4f |
|00006140| 56 29 5e 25 39 2e 34 66 | 20 b1 20 25 39 2e 34 66 |V)^%9.4f| . %9.4f|
|00006150| 5c 6e 22 2c 70 5b 31 5d | 2c 70 5b 32 5d 2c 70 5b |\n",p[1]|,p[2],p[|
|00006160| 33 5d 2c 70 5b 34 5d 2c | 66 72 65 74 29 3b 0d 09 |3],p[4],|fret);..|
|00006170| 66 6f 72 28 69 3d 30 3b | 69 3c 34 3b 69 2b 2b 29 |for(i=0;|i<4;i++)|
|00006180| 20 4c 50 2d 3e 70 6f 77 | 65 72 5b 69 5d 3d 70 5b | LP->pow|er[i]=p[|
|00006190| 69 2b 31 5d 3b 0d 09 66 | 72 65 65 5f 76 65 63 74 |i+1];..f|ree_vect|
|000061a0| 6f 72 28 70 2c 31 2c 34 | 29 3b 0d 09 66 72 65 65 |or(p,1,4|);..free|
|000061b0| 5f 6d 61 74 72 69 78 28 | 78 69 2c 31 2c 34 2c 31 |_matrix(|xi,1,4,1|
|000061c0| 2c 34 29 3b 0d 09 65 3d | 30 2e 30 3b 0d 09 66 6f |,4);..e=|0.0;..fo|
|000061d0| 72 28 69 3d 30 3b 69 3c | 6e 4c 3b 69 2b 2b 29 7b |r(i=0;i<|nL;i++){|
|000061e0| 0d 09 09 66 3d 4c 50 2d | 3e 70 6f 77 65 72 5b 31 |...f=LP-|>power[1|
|000061f0| 5d 2b 4c 50 2d 3e 70 6f | 77 65 72 5b 32 5d 2a 56 |]+LP->po|wer[2]*V|
|00006200| 5b 69 5d 3b 0d 09 09 69 | 66 28 66 3e 30 2e 30 29 |[i];...i|f(f>0.0)|
|00006210| 20 66 3d 4c 50 2d 3e 70 | 6f 77 65 72 5b 30 5d 2b | f=LP->p|ower[0]+|
|00006220| 70 6f 77 28 66 2c 4c 50 | 2d 3e 70 6f 77 65 72 5b |pow(f,LP|->power[|
|00006230| 33 5d 29 3b 0d 09 09 65 | 6c 73 65 20 66 3d 4c 50 |3]);...e|lse f=LP|
|00006240| 2d 3e 70 6f 77 65 72 5b | 30 5d 3b 0d 09 09 65 2b |->power[|0];...e+|
|00006250| 3d 28 4c 5b 69 5d 2d 66 | 29 2a 28 4c 5b 69 5d 2d |=(L[i]-f|)*(L[i]-|
|00006260| 66 29 3b 0d 09 7d 0d 09 | 4c 50 2d 3e 70 6f 77 65 |f);..}..|LP->powe|
|00006270| 72 45 72 72 6f 72 20 3d | 20 73 71 72 74 28 65 2f |rError =| sqrt(e/|
|00006280| 6e 4c 29 3b 0d 09 4c 50 | 2d 3e 56 4d 69 6e 3d 30 |nL);..LP|->VMin=0|
|00006290| 3b 09 09 09 09 09 2f 2a | 20 6d 69 6e 69 6d 75 6d |;...../*| minimum|
|000062a0| 20 76 61 6c 75 65 20 74 | 68 61 74 20 63 61 6e 20 | value t|hat can |
|000062b0| 62 65 20 6c 6f 61 64 65 | 64 20 69 6e 74 6f 20 44 |be loade|d into D|
|000062c0| 41 43 20 2a 2f 0d 09 4c | 50 2d 3e 56 4d 61 78 3d |AC */..L|P->VMax=|
|000062d0| 28 31 4c 3c 3c 4c 50 2d | 3e 64 61 63 53 69 7a 65 |(1L<<LP-|>dacSize|
|000062e0| 29 2d 31 3b 09 2f 2a 20 | 6d 61 78 69 6d 75 6d 20 |)-1;./* |maximum |
|000062f0| 76 61 6c 75 65 20 74 68 | 61 74 20 63 61 6e 20 62 |value th|at can b|
|00006300| 65 20 6c 6f 61 64 65 64 | 20 69 6e 74 6f 20 44 41 |e loaded| into DA|
|00006310| 43 20 2a 2f 0d 09 4c 50 | 2d 3e 4c 4d 69 6e 3d 56 |C */..LP|->LMin=V|
|00006320| 54 6f 4c 28 4c 50 2c 4c | 50 2d 3e 56 4d 69 6e 29 |ToL(LP,L|P->VMin)|
|00006330| 3b 09 2f 2a 20 6d 69 6e | 20 6c 75 6d 69 6e 61 6e |;./* min| luminan|
|00006340| 63 65 20 2a 2f 0d 09 4c | 50 2d 3e 4c 4d 61 78 3d |ce */..L|P->LMax=|
|00006350| 56 54 6f 4c 28 4c 50 2c | 4c 50 2d 3e 56 4d 61 78 |VToL(LP,|LP->VMax|
|00006360| 29 3b 09 2f 2a 20 6d 61 | 78 20 6c 75 6d 69 6e 61 |);./* ma|x lumina|
|00006370| 6e 63 65 20 2a 2f 0d 09 | 0d 09 2f 2a 20 70 6f 77 |nce */..|../* pow|
|00006380| 65 72 20 6c 61 77 20 66 | 69 74 20 77 69 74 68 20 |er law f|it with |
|00006390| 61 20 46 49 58 45 44 20 | 67 61 6d 6d 61 20 2a 2f |a FIXED |gamma */|
|000063a0| 0d 09 2f 2a 20 54 68 69 | 73 20 69 73 20 73 6f 6c |../* Thi|s is sol|
|000063b0| 65 6c 79 20 66 6f 72 20 | 73 74 75 64 79 20 6f 66 |ely for |study of|
|000063c0| 20 74 68 65 20 65 66 66 | 65 63 74 73 20 6f 66 20 | the eff|ects of |
|000063d0| 74 68 65 20 63 6f 6e 74 | 72 61 73 74 20 61 6e 64 |the cont|rast and|
|000063e0| 20 62 72 69 67 68 74 6e | 65 73 73 20 6b 6e 6f 62 | brightn|ess knob|
|000063f0| 73 20 2a 2f 0d 09 2f 2a | 20 4c 3d 70 5b 31 5d 2b |s */../*| L=p[1]+|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.